当前位置: 首页 > news >正文

【RabbitMQ】使用SpringAMQP的Publish/Subscribe(发布/订阅)

Publish/Subscribe

**发布(Publish)、订阅(Subscribe):**允许将同一个消息发送给多个消费者

在这里插入图片描述

**注意:**exchange负责消息路由,而不是存储,路由失败则消息丢失

常见的**X(exchange–交换机)***类型:

  • Fanout 广播
  • Direct 路由
  • Topoc 话题

发布订阅–FanoutExchange

案例三:利用SpringAMQP演示广播交换机的使用

1.在消费者(consumer包)中,创建一个FanoutConfig类,声明队列、交换机,并将两者绑定
@Configuration
public class FanoutConfig {//声明FanoutExchange交换机itcast.fanout@Beanpublic FanoutExchange fanoutExchange(){return new FanoutExchange("itcast.fanout");}//声明fanout.queue1队列@Beanpublic Queue fanoutQueue1(){return new Queue("fanout.queue1");}//绑定fanout.queue1队列和交换机@Beanpublic Binding bindingQueue1(Queue fanoutQueue1, FanoutExchange fanoutExchange){return BindingBuilder.bind(fanoutQueue1).to(fanoutExchange);}//声明fanout.queue2队列@Beanpublic Queue fanoutQueue2(){return new Queue("fanout.queue2");}//绑定fanout.queue2队列和交换机@Beanpublic Binding bindingQueue2(Queue fanoutQueue2, FanoutExchange fanoutExchange){return BindingBuilder.bind(fanoutQueue2).to(fanoutExchange);}
}
2.在消费者(consumer包)中,编写两个消费者SpringRabbitListener方法,分别监听fanout.queue1和fanout.queue2
@Component
public class SpringRabbitListener {@RabbitListener(queues = "fanout.queue1")public void listenFanoutQueue1(String msg) {System.out.println("消费者接收到fanout.queue1的消息:【" + msg + "】");}@RabbitListener(queues = "fanout.queue2")public void listenFanoutQueue2(String msg) {System.out.println("消费者接收到fanout.queue2的消息:【" + msg + "】");}}
3.在publiSher中编写测试方法,向itcast.fanout发送消息
@RunWith(SpringRunner.class)
@SpringBootTest
public class SpringAmqpTest {@Autowiredprivate RabbitTemplate rabbitTemplate;@Testpublic void testSendFanoutExchange() {// 交换机名称String exchangeName = "itcast.fanout";// 消息String message = "hello, every one!";// 发送消息rabbitTemplate.convertAndSend(exchangeName, "", message);}
}
4.运行,结果

在这里插入图片描述

发布订阅–DirectExchange

将接收到的消息根据规则路由到指定的Queue,因此称为路由模式(routes)

  • 每一个Queue都与Exchange设置一个BindingKey(暗号)
  • 发布者发送消息时,指定消息的RoutingKey
  • Exchange将消息路由到BindingKey与消息RoutingKey一致的队列

在这里插入图片描述

案例四:利用SpringAMQP演示DirectExchange的使用

1.直接用注解
@RabbitListener声明Exchange、Queue、RoutingKey
@QueueBinding注解用于绑定队列和交换器,并指定路由键
@Component
public class SpringRabbitListener {@RabbitListener(bindings = @QueueBinding(value = @Queue(name = "direct.queue1"),exchange = @Exchange(name = "itcast.direct", type = ExchangeTypes.DIRECT),key = {"red", "blue"}))public void listenDirectQueue1(String msg){System.out.println("消费者接收到direct.queue1的消息:【" + msg + "】");}@RabbitListener(bindings = @QueueBinding(value = @Queue(name = "direct.queue2"),exchange = @Exchange(name = "itcast.direct", type = ExchangeTypes.DIRECT),key = {"red", "yellow"}))public void listenDirectQueue2(String msg){System.out.println("消费者接收到direct.queue2的消息:【" + msg + "】");}}

在这里插入图片描述

2.测试
@RunWith(SpringRunner.class)
@SpringBootTest
public class SpringAmqpTest {@Autowiredprivate RabbitTemplate rabbitTemplate;@Testpublic void testSendDirectExchange() {// 交换机名称String exchangeName = "itcast.direct";// 消息String message = "hello, red!";// 发送消息rabbitTemplate.convertAndSend(exchangeName, "red", message);}
}
3.结果

在这里插入图片描述

发布订阅–TopicExchange

TopicExchange与DirectExchange类似,区别在于routingKey必须是多个单词的列表,并且以**.**分割

Queue与Exchange指定BindingKey时可以使用通配符

  • # : 代指0个或多个单词
  • * : 代指一个单词

在这里插入图片描述

案例五:利用SpringAMQP演示TopicExchange的使用

1.直接用注解
@RabbitListener声明Exchange、Queue、RoutingKey
@QueueBinding注解用于绑定队列和交换器,并指定路由键
@Component
public class SpringRabbitListener {@RabbitListener(bindings = @QueueBinding(value = @Queue(name = "topic.queue1"),exchange = @Exchange(name = "itcast.topic", type = ExchangeTypes.TOPIC),key = "china.#"))public void listenTopicQueue1(String msg){System.out.println("消费者接收到topic.queue1的消息:【" + msg + "】");}@RabbitListener(bindings = @QueueBinding(value = @Queue(name = "topic.queue2"),exchange = @Exchange(name = "itcast.topic", type = ExchangeTypes.TOPIC),key = "#.news"))public void listenTopicQueue2(String msg){System.out.println("消费者接收到topic.queue2的消息:【" + msg + "】");}
}

在这里插入图片描述

2.测试
@RunWith(SpringRunner.class)
@SpringBootTest
public class SpringAmqpTest {@Autowiredprivate RabbitTemplate rabbitTemplate;@Testpublic void testSendTopicExchange() {// 交换机名称String exchangeName = "itcast.topic";// 消息String message = "合理小姐是凑巧先生独一无二的女主角";//String message = "今天天气不错,我的心情好极了!";// 发送消息rabbitTemplate.convertAndSend(exchangeName, "china.news", message);//rabbitTemplate.convertAndSend(exchangeName, "china.weather", message);}}
3.结果

在这里插入图片描述

相关文章:

  • 【大模型部署】在C# Winform中使用文心一言ERNIE-3.5 4K 聊天模型
  • Hive环境搭建
  • 从 0 手撸一个 pytorch
  • 中国联通国际在商业零售领域的全球网络与SDN网络技术应用
  • ANDROID OLLVM 混淆配置
  • 【OpenCV】像素信息统计
  • redis数据类型之string,list
  • zabbix配置自动发现规则模版-snmp
  • 谢宁DOE培训适合哪些人?
  • Java面试八股之自旋是什么意思
  • 聚酯输送带的原材料
  • 在winnas中使用docker desktop遇到的问题及解决方法记录
  • 【C++】构造函数、析构函数、拷贝构造与运算符重载
  • 乡村振兴的乡村旅游新模式:挖掘乡村旅游资源,创新旅游开发方式,打造乡村旅游新品牌,助力美丽乡村建设
  • 迅睿 CMS 中开启【ionCube 扩展】的方法
  • 【RocksDB】TransactionDB源码分析
  • Android框架之Volley
  • HomeBrew常规使用教程
  • JAVA之继承和多态
  • Travix是如何部署应用程序到Kubernetes上的
  • vue 个人积累(使用工具,组件)
  • 产品三维模型在线预览
  • 道格拉斯-普克 抽稀算法 附javascript实现
  • 第三十一到第三十三天:我是精明的小卖家(一)
  •  一套莫尔斯电报听写、翻译系统
  • 好程序员大数据教程Hadoop全分布安装(非HA)
  • 资深实践篇 | 基于Kubernetes 1.61的Kubernetes Scheduler 调度详解 ...
  • ​MySQL主从复制一致性检测
  • !!【OpenCV学习】计算两幅图像的重叠区域
  • # MySQL server 层和存储引擎层是怎么交互数据的?
  • #我与Java虚拟机的故事#连载14:挑战高薪面试必看
  • %@ page import=%的用法
  • (离散数学)逻辑连接词
  • (深度全面解析)ChatGPT的重大更新给创业者带来了哪些红利机会
  • (算法)N皇后问题
  • (原創) 是否该学PetShop将Model和BLL分开? (.NET) (N-Tier) (PetShop) (OO)
  • * 论文笔记 【Wide Deep Learning for Recommender Systems】
  • .cfg\.dat\.mak(持续补充)
  • .gitignore文件忽略的内容不生效问题解决
  • .net core 调用c dll_用C++生成一个简单的DLL文件VS2008
  • .NET DevOps 接入指南 | 1. GitLab 安装
  • .NET3.5下用Lambda简化跨线程访问窗体控件,避免繁复的delegate,Invoke(转)
  • .Net面试题4
  • .net通用权限框架B/S (三)--MODEL层(2)
  • .NET性能优化(文摘)
  • @JsonSerialize注解的使用
  • [20150707]外部表与rowid.txt
  • [Android]使用Git将项目提交到GitHub
  • [bzoj 3534][Sdoi2014] 重建
  • [C#]科学计数法(scientific notation)显示为正常数字
  • [CF482B]Interesting Array
  • [codevs 1288] 埃及分数 [IDdfs 迭代加深搜索 ]
  • [docker] Docker的私有仓库部署——Harbor
  • [MFC] MFC消息机制的补充
  • [mysql]游标和触发器