Spring Boot整合RabbitMQ开发实战详解

网友投稿 233 2023-02-19


Spring Boot整合RabbitMQ开发实战详解

这篇文章主要讲基本的整合。先把代码跑起来,再说什么高级特性。

RabbitMQ 中的一些术语

如果你打开 RabbitMQ web 控制台,你会发现其中有一个 Exhanges 不好理解。下面简单说明一下。

交换器(Exchange)

交换器就像路由器,我们先是把消息发到交换器,然后交换器再根据路由键(routingKey)把消息投递到对应的队列。(明白这个概念很重要,后面的代码里面充分体现了这一点)

队列(Queue)

队列很好理解,就不用解释了。

绑定(Binding)

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

加入 RabbitMQ maven 依赖

org.springframework.boot

spring-boot-starter-amqp

再加入另外一个依赖(这个依赖可省略,主要是用来简化代码)

cn.hutool

hutool-all

4.0.2

RabbitMQConfig.java 配置

@Configuration

public class RabbitMQConfig {

public final statihttp://c String QUEUE_NAME = "spring-boot-queue";

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

public final static String ROUTING_KEY = "spring-boot-key";

// 创建队列

@Bean

public Queue queue() {

return new Queue(QUEUE_NAME);

}

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

@Bean

http://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(ROUTING_KEY);

}

@Bean

public ConnectionFactory connectionFactory() {

CachingConnectionFactory connectionFactory = new CachingConnectionFactory("127.0.WKVJtIclZ0.1", 5672);

connectionFactory.setUsername("guest");

connectionFactory.setPassword("guest");

return connectionFactory;

}

@Bean

public RabbitTemplate rabbitTemplate(ConnectionFactory connectionFactory) {

return new RabbitTemplate(connectionFactory);

}

}

生产者

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

@RestController

public class ProducerController {

@Autowired

private RabbitTemplate rabbitTemplate;

@GetMapping("/sendMessage")

public Object 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 注解,指定需要监听的队列名称即可。

@Component

public class Consumer {

@RabbitListener(queues = RabbitMQConfig.QUEUE_NAME)

public void consumeMessage(String message) {

Console.log("consume message {}", message);

}

}

运行项目

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

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

点击进入交换器的详情

结语


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:详解vue静态资源打包中的坑与解决方案
下一篇:使用百度地图实现地图网格的示例
相关文章

 发表评论

暂时没有评论,来抢沙发吧~