我们把一个消息转发给多个消费者,这种模式称之为发布-订阅模式

1.交换器(Exchange)

RabbitMq消息模式的核心思想是:一个生产者并不会直接往一个队列中发送消息,事实上,生产者根本不知道它发送的消息将被转发到哪些队列。

实际上,生产者只能把消息发送给一个exchange,exchange只做一件简单的事情:一方面它们接收从生产者发送过来的消息,另一方面,它们把接收到的消息推送给队列

2. 临时队列

AnonymousQueue是非持久化、专有的、自动删除的、名字随机生成的队列

3. 绑定(Binding)

交换器与队列之间的关系称之为绑定关系

4. 完整代码
  • 新建MqConfig.java已建立队列及其绑定
@Configuration
public class MqConfig { @Bean
public FanoutExchange fanout() {
return new FanoutExchange("fanout");
} private static class ConsumerConfig { @Bean
public Queue autoDeleteQueue1() {
return new AnonymousQueue();
} @Bean
public Queue autoDeleteQueue2() {
return new AnonymousQueue();
} @Bean
public Binding binding1(FanoutExchange fanout, Queue autoDeleteQueue1) {
return BindingBuilder.bind(autoDeleteQueue1).to(fanout);
} @Bean
public Binding binding2(FanoutExchange fanout, Queue autoDeleteQueue2) {
return BindingBuilder.bind(autoDeleteQueue2).to(fanout);
}
}
}
  • 新建生产者
@Component
public class FanoutSender { private RabbitTemplate rabbitTemplate; public FanoutSender(RabbitTemplate rabbitTemplate) {
this.rabbitTemplate = rabbitTemplate;
} public void send() {
String msg = "Hello World!";
// fanout为交换器名称
rabbitTemplate.convertAndSend("fanout", "", msg);
}
}
  • 新建消费者
@Component
public class FanoutReceiver { // autoDeleteQueue1.name为匿名队列的名称
@RabbitListener(queues = "#{autoDeleteQueue1.name}")
public void receive1(String in) {
System.out.println("临时队列1接收到消息:" + in);
} @RabbitListener(queues = "#{autoDeleteQueue2.name}")
public void receive2(String in) {
System.out.println("临时队列2接收到消息:" + in);
}
}
  • 新建测试类
@SpringBootTest
public class RabbitTest { @Autowired
private FanoutSender fanoutSender; @Test
public void testFanoutSender() {
fanoutSender.send();
}
}
  • 运行测试类后匿名队列1与2接收到消息

欢迎关注公众号算法小生沈健的技术博客

最新文章

  1. c++并发练习---多线程顺序打印
  2. 手机页面touch触摸事件
  3. protect和private 的区别
  4. 二维KMP - 求字符矩阵的最小覆盖矩阵 - poj 2185
  5. AttributeError: 'NoneType' object has no attribute 'bytes' python3.4 win64
  6. scala学习笔记(8): 列表的map,flatMap,zip和reduce
  7. jquery之音乐均衡器
  8. 省市区 Mysql 数据库表
  9. Activiti安装
  10. JNI调用native方法出现 java.lang.UnsatisfiedLinkError: XXXclass.XXXmethod()异常的解决办法
  11. Android学习总结——系统提示对话框(AlertDialog)
  12. require include 一个隐藏的用法:作用域。
  13. 移动webAPP前端开发技巧汇总2
  14. 【61】git项目实战的步骤总结
  15. 微信小程序创建一个新项目
  16. Python基础之面向对象进阶二
  17. ionic 2.x 3.x input触发调用键盘搜索及事件
  18. 图解RAID 0, RAID 1, RAID 5, RAID 10
  19. Python.__getattr__Vs__getattribute__
  20. 从零搭建HBase集群

热门文章

  1. Vue 引出声明周期 && 组件的基本使用
  2. Computational Protein Design with Deep Learning Neural Networks
  3. React报错之Style prop value must be an object
  4. 笃情开源:我和 Apache DolphinScheduler 社区的故事
  5. ASP.NET Core自定义中间件的方式
  6. numa 自动balance 的bug分析
  7. Linux安装LibreCAD
  8. 《Java编程思想》读书笔记(四)
  9. 全能成熟稳定开源分布式存储Ceph破冰之旅-上
  10. 部署Netlify站点博客