4.RabbitMQ系列之发布/订阅模式
2024-09-08 14:06:11
我们把一个消息转发给多个消费者,这种模式称之为发布-订阅模式
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接收到消息
最新文章
- c++并发练习---多线程顺序打印
- 手机页面touch触摸事件
- protect和private 的区别
- 二维KMP - 求字符矩阵的最小覆盖矩阵 - poj 2185
- AttributeError: 'NoneType' object has no attribute 'bytes' python3.4 win64
- scala学习笔记(8): 列表的map,flatMap,zip和reduce
- jquery之音乐均衡器
- 省市区 Mysql 数据库表
- Activiti安装
- JNI调用native方法出现 java.lang.UnsatisfiedLinkError: XXXclass.XXXmethod()异常的解决办法
- Android学习总结——系统提示对话框(AlertDialog)
- require include 一个隐藏的用法:作用域。
- 移动webAPP前端开发技巧汇总2
- 【61】git项目实战的步骤总结
- 微信小程序创建一个新项目
- Python基础之面向对象进阶二
- ionic 2.x 3.x input触发调用键盘搜索及事件
- 图解RAID 0, RAID 1, RAID 5, RAID 10
- Python.__getattr__Vs__getattribute__
- 从零搭建HBase集群
热门文章
- Vue 引出声明周期 &;&; 组件的基本使用
- Computational Protein Design with Deep Learning Neural Networks
- React报错之Style prop value must be an object
- 笃情开源:我和 Apache DolphinScheduler 社区的故事
- ASP.NET Core自定义中间件的方式
- numa 自动balance 的bug分析
- Linux安装LibreCAD
- 《Java编程思想》读书笔记(四)
- 全能成熟稳定开源分布式存储Ceph破冰之旅-上
- 部署Netlify站点博客