当前位置:
首页 >
前端技术
> javascript
>内容正文
javascript
SpringBoot整合RabbitMQ 实现五种消息模型
生活随笔
收集整理的这篇文章主要介绍了
SpringBoot整合RabbitMQ 实现五种消息模型
小编觉得挺不错的,现在分享给大家,帮大家做个参考.
目录
- SpringBoot中使用RabbitMQ
- 搭建初始环境
- 引入依赖
- 配置配置文件
- 测试类 注入 rabbitTemplate
- 消息队列RabbitMQ之五种消息模型
- 第一种直连模型使用
- 开发生产者
- 开发消费者
- 第二种work模型使用
- 开发生产者
- 开发消费者
- 第三种 Fanout 广播模型
- 开发生产者
- 开发消费者
- 第四种 Route 路由模型
- 开发生产者
- 开发消费者
- 第五种 Topic 订阅模型(动态路由模型)
- 开发生产者
- 开发消费者
SpringBoot中使用RabbitMQ
搭建初始环境
引入依赖
<!-- 引入 rabbitmq 集成依赖 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-amqp</artifactId></dependency>配置配置文件
server:port: 9090spring:application:# 微服务系统有意义, 养成好习惯, 先写出来name: rabbitmq-02-springbootrabbitmq:host: 127.0.0.1port: 5672username: codingcepassword: 123456virtual-host: /codingce测试类 注入 rabbitTemplate
// 注入 rabbitTemplate@Autowiredprivate RabbitTemplate rabbitTemplate;消息队列RabbitMQ之五种消息模型
第一种直连模型使用
开发生产者
/*** 直连*/@Testvoid contextLoads() {rabbitTemplate.convertAndSend("hello", "hello word");}开发消费者
/*** @author mxz*/ @Component @RabbitListener(queuesToDeclare = @Queue("hello")) public class HelloCustomer {/*** @param message*/@RabbitHandlerpublic void receivel(String message) {System.out.println("message: " + message);}}第二种work模型使用
开发生产者
/*** work*/@Testvoid testWork() {for (int i = 0; i < 10; i++) {rabbitTemplate.convertAndSend("work", "work模型");}}开发消费者
/*** 第二种模型 work 模型** @author mxz*/ @Component public class WorkCustomer {/*** 第1个消费者** @param message*/@RabbitListener(queuesToDeclare = @Queue("work"))public void receivel(String message) {System.out.println("message1 = " + message);}/*** 第2个消费者** @param message*/@RabbitListener(queuesToDeclare = @Queue("work"))public void receivel2(String message) {System.out.println("message2 = " + message);} }第三种 Fanout 广播模型
开发生产者
/*** fanout 广播*/@Testvoid testFanout() {rabbitTemplate.convertAndSend("logs", "", "Fanout模型发送的消息");}开发消费者
/*** fanout** @author mxz*/ @Component public class FanoutCustomer {@RabbitListener(bindings = {@QueueBinding(value = @Queue, // 创建临时队列exchange = @Exchange(value = "logs", type = "fanout") // 绑定的交换机)})public void receivel(String message) {System.out.println("message1 = " + message);}@RabbitListener(bindings = {@QueueBinding(value = @Queue, // 创建临时队列exchange = @Exchange(value = "logs", type = "fanout") // 绑定的交换机)})public void receive2(String message) {System.out.println("message2 = " + message);} }第四种 Route 路由模型
开发生产者
/*** route 路由*/@Testvoid testRoute() {// exchange 交换机名称rabbitTemplate.convertAndSend("directs", "info", "info的key的路由消息");}开发消费者
/*** @author mxz*/ @Component public class RouteCustomer {@RabbitListener(bindings = {@QueueBinding(value = @Queue, // 绑定临时队列exchange = @Exchange(value = "directs", type = "direct"), // 自定义交换机名称和类型key = {"info", "error", "warn"})})public void receivel(String message) {System.out.println("message1 = " + message);}@RabbitListener(bindings = {@QueueBinding(value = @Queue, // 绑定临时队列exchange = @Exchange(value = "directs", type = "direct"), // 自定义交换机名称和类型key = {"error"})})public void receivel2(String message) {System.out.println("message1 = " + message);}}第五种 Topic 订阅模型(动态路由模型)
开发生产者
/*** topic 订阅模式 动态路由*/@Testvoid testTopic() {rabbitTemplate.convertAndSend("topics", "user.save", "user.save 路由消息");}开发消费者
/*** 订阅模型** @author mxz*/ @Component public class TopicCustomer {@RabbitListener(bindings = {@QueueBinding(value = @Queue,exchange = @Exchange(type = "topic", name = "topics"),key = {"user.save", "user.*"})})public void receivel(String message) {System.out.println("message1" + message);}@RabbitListener(bindings = {@QueueBinding(value = @Queue,exchange = @Exchange(type = "topic", name = "topics"),key = {"produce.#", "order.#"})})public void receivel2(String message) {System.out.println("message2" + message);} }文章已上传gitee https://gitee.com/codingce/hexo-blog
项目地址github: https://github.com/xzMhehe/codingce-java
总结
以上是生活随笔为你收集整理的SpringBoot整合RabbitMQ 实现五种消息模型的全部内容,希望文章能够帮你解决所遇到的问题。
- 上一篇: RabbitMQ 消息队列六种模式
- 下一篇: JSR-303