博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
RabbitMQ基础组件和SpringBoot整合RabbitMQ简单示例
阅读量:7201 次
发布时间:2019-06-29

本文共 1846 字,大约阅读时间需要 6 分钟。

交换器(Exchange)

交换器就像路由器,我们先是把消息发到交换器,然后交换器再根据绑定键(binding key)和生产者发送消息时的路由键routingKey,

按照交换类型Exchange Type(fanoutdirecttopic)把消息投递到对应的队列。(明白这个概念很重要,后面的代码里面充分体现了这一点)。

RabbitMQ基础知识可查看

队列(Queue)

存放消息的队列。

绑定(Binding)

交换器怎么知道把这条消息投递到哪个队列呢?这就需要用到绑定了。大概就是:使用某个绑定键(binding key),把某个队列(Queue)绑定到某个交换器(Exchange),这样交换器就知道根据路由键把这条消息投递到哪个队列了。(后面的代码里面充分体现了这一点)

加入 RabbitMQ maven 依赖

RabbitMQ实战(一)Spring Boot 整合 RabbitMQ

 

配置

application.yaml文件中配置

RabbitMQ实战(一)Spring Boot 整合 RabbitMQ

 

RabbitMQConfig.java 配置

@Configuration

public class RabbitMQConfig {

public final static String QUEUE_NAME = "spring-boot-queue";

public final static String EXCHANGE_NAME = "spring-boot-exchange";

public final static String BINDING_KEY = "spring.boot.key.#";

// 创建队列

@Bean

public Queue queue() {

return new Queue(QUEUE_NAME);

}

// 创建一个 topic 类型的交换器

@Bean

public TopicExchange exchange() {

return new TopicExchange(EXCHANGE_NAME);

}

// 使用路由键(routingKey)把队列(Queue)绑定到交换器(Exchange)

@Bean

public Binding binding(Queue queue, TopicExchange exchange) {

return BindingBuilder.bind(queue).to(exchange).with(BINDING_KEY);

}

}

注:上面配置的是TopicExchange

实际业务中,可以配置多个队列和binding来满足需求。

生产者

直接调用 rabbitTemplate 的 convertAndSend 方法就可以了。从下面的代码里也可以看出,我们不是把消息直接发送到队列里面的,而是先发送到了交换器,交换器再根据路由键把我们的消息投递到对应的队列。

@RestController

public class ProducerController {

@Autowired

private RabbitTemplate rabbitTemplate;

@GetMapping("/sendMessage")

public String sendMessage() {

new Thread(() -> {

for (int i = 0; i < 100; i++) {

String value = new DateTime().toString("yyyy-MM-dd HH:mm:ss");

Console.log("send message {}", value);

rabbitTemplate.convertAndSend(RabbitMQConfig.EXCHANGE_NAME, RabbitMQConfig.ROUTING_KEY, value);

}

}).start();

return "ok";

}

}

消费者

消费者也很简单,只需要对应的方法上加入 @RabbitListener 注解,指定需要监听的队列名称即可。

RabbitMQ实战(一)Spring Boot 整合 RabbitMQ

 

运行项目

运行项目,然后打开浏览器,输入 http://localhost:9999/sendMessage(具体地址根据服务器)。在控制台就可以看到生产者在不停的的发送消息,消费者不断的在消费消息。

RabbitMQ实战(一)Spring Boot 整合 RabbitMQ

 

控制台

打开 RabbitMQ web 控制台,也可以看到刚才我们在代码里面配置的交换器和队列,以及绑定信息。

RabbitMQ实战(一)Spring Boot 整合 RabbitMQ

 

查看交换器的详情

RabbitMQ实战(一)Spring Boot 整合 RabbitMQ

 

查看队列

RabbitMQ实战(一)Spring Boot 整合 RabbitMQ
 
本文转自:

转载地址:http://uszum.baihongyu.com/

你可能感兴趣的文章
大端小端格式
查看>>
rocketmq(1)
查看>>
UI- font 字体设置
查看>>
彻底搞懂 call() 和 apply() 方法
查看>>
[转] 现实•理论•证据──谈如何做研究和写论文
查看>>
第一二次Java实训
查看>>
http协议详解2
查看>>
linux下的工作模型以及Nginx工作原理
查看>>
利用Python进行文章特征提取(一)
查看>>
骆家辉 干的好事,忽悠清华大学,
查看>>
,非你莫属,
查看>>
第五周作业
查看>>
了解Session的本质
查看>>
Sass 入门 (一) 安装Sass
查看>>
进程与线程的一个简单解释
查看>>
【HDOJ】3789 奥运排序问题
查看>>
【Linux】鸟哥的Linux私房菜基础学习篇整理(十二)
查看>>
20-黑马程序员------OC 语言学习笔记---多态
查看>>
STC12C5A60S2 双串口通信
查看>>
Arrow function restore
查看>>