欢迎来到"雪碧聊技术"CSDN博客!
在这里,您将踏入一个专注于Java开发技术的知识殿堂。无论您是Java编程的初学者,还是具有一定经验的开发者,相信我的博客都能为您提供宝贵的学习资源和实用技巧。作为您的技术向导,我将不断探索Java的深邃世界,分享最新的技术动态、实战经验以及项目心得。
让我们一同在Java的广阔天地中遨游,携手提升技术能力,共创美好未来!感谢您的关注与支持,期待在"雪碧聊技术"与您共同成长!
目录
③结论:fanout交换机,是广播的,即:与fanout交换机绑定的所有队列,都会收到交换机中的消息。
5、注意:如果一个队列要绑定多个RoutingKey,需要绑定多次
一、Fanout交换机(广播转发)
1、什么是Fanout交换机?
Fanout 交换机(Exchange)会将接收到的消息广播到每一个跟其绑定的queue,所以也叫广播模式。
2、案例
①案例介绍
data:image/s3,"s3://crabby-images/9c0ec/9c0ec6adc0e59a6998c0cf6ba859bc74b96913cf" alt=""
②具体操作
- 第一步:在RabbitMQ控制台,创建两个队列fanout.queue1和fanout.queue2
data:image/s3,"s3://crabby-images/3bfc8/3bfc8720d8e639f0bf3a397da62ce87acf30c164" alt=""
- 第二步:添加一台Fanout类型的交换机,名叫"hmall.fanout"
data:image/s3,"s3://crabby-images/c08ae/c08ae632efa6359615b5dd1ae2b4de60cc7e4c35" alt=""
- 第三步:给hmall.fanout交换机绑定刚才那两个队列
data:image/s3,"s3://crabby-images/8b6e5/8b6e532810bf98d2d18ef1a1b0f08165fa77a2b9" alt=""
- 第四步:编写代码,给hmall.fanout交换机发送一条消息
data:image/s3,"s3://crabby-images/94859/94859970eaab12b13891ae205ede15cff95e629e" alt=""
- 第五步:编写监听代码,监听与hmall.fanout交换机绑定的两个队列
java
@Component //交给spring管理
public class MqListener {
@RabbitListener(queues = "fanout.queue1")
public void listenFanoutQueue1(String msg) throws InterruptedException {//消费者1
System.out.println("消费者1 收到了 fanout.queue1的消息... :【" + msg + "】");
}
@RabbitListener(queues = "fanout.queue2")
public void listenFanoutQueue2(String msg) throws InterruptedException {//消费者2
System.err.println("消费者2 收到了 fanout.queue2的消息... :【" + msg + "】");
}
}
- 第六步:运行项目,查看结果
java
消费者1 收到了 fanout.queue1的消息... :【hello,everyone!】
消费者2 收到了 fanout.queue2的消息... :【hello,everyone!】
③结论:fanout交换机,是广播的,即:与fanout交换机绑定的所有队列,都会收到交换机中的消息。
3、总结
data:image/s3,"s3://crabby-images/ebffa/ebffa1c93d4035dd4cb225ab76c6ac16018d5ecd" alt=""
二、Direct交换机(定向转发)
1、什么是Direct交换机?
Direct交换机会根据一定规则,将收到的消息,转发给对应的队列。
2、如何确定Direct交换机给哪个队列转发消息?
①publisher(生产者)给Direct交换机发送消息的时候,会给该条消息添加一个RoutingKey。
②给Direct交换机绑定队列时,也要指定每个队列的RoutingKey。
这么一来,当Direct交换机收到publisher(生产者)的消息后,会读取该条消息的RoutingKey,找到拥有该RoutingKey的那个队列,并给该队列转发消息。
举例
data:image/s3,"s3://crabby-images/0250d/0250dc16763eccb270019d42f206a5c7f7b7ef26" alt=""
3、案例
①案例介绍
data:image/s3,"s3://crabby-images/04038/040386db1906dc0f73d950a5f7528e1ee284388b" alt=""
②具体操作
- 第一步:创建两个队列direct.queue1和direct.queue2
data:image/s3,"s3://crabby-images/08aa5/08aa5f178e1038958f51994e2e2eb9c04790aec2" alt=""
- 第二步:创建一个Direct类型的交换机
data:image/s3,"s3://crabby-images/5a61d/5a61d890808c67e9b49a57c16e751452c8b4b201" alt=""
- 第三步:给hmall.direct交换机绑定那两个队列,并指定其RoutingKey
data:image/s3,"s3://crabby-images/a022d/a022d901cf84b915aeaa9480c84ea1c33166bb3c" alt=""
data:image/s3,"s3://crabby-images/85641/8564180df738836898cc67c69e9350477204670b" alt=""
结果如下:
data:image/s3,"s3://crabby-images/c7359/c7359136f13cec6c5230f243bfd3dde6537a83d3" alt=""
- 第四步:编写代码,发送一条消息给hmall.direct交换机
data:image/s3,"s3://crabby-images/e2b90/e2b90a03d0537c645be71bf3d3ced0f5e70aac59" alt=""
- 第五步:编写监听direct.queue1和direct.queue2两个队列的代码
java
@Component //交给spring管理
public class MqListener {
@RabbitListener(queues = "direct.queue1")
public void listenDirectQueue1(String msg) throws InterruptedException {//消费者1
System.out.println("消费者1 收到了 direct.queue1的消息... :【" + msg + "】");
}
@RabbitListener(queues = "direct.queue2")
public void listenDirectQueue2(String msg) throws InterruptedException {//消费者2
System.out.println("消费者2 收到了 direct.queue2的消息... :【" + msg + "】");
}
}
- 第六步:运行项目,查看结果
java
消费者2 收到了 direct.queue2的消息... :【红色警报,由于日本排放核污水,惊险哥斯拉!】
可见,由于direct.queue2的RoutingKey是"red",因此能收到此条消息(因为此条消息的RoutingKey也是"red")。
4、总结
生产者给Direct类型的交换机发送消息时,要指定该消息的RoutingKey;
给Direct类型的交换机绑定队列时,也要指定队列的RoutingKey;
Direct类型的交换机在转发消息时,只转发给RoutingKey一致的队列。
5、注意:如果一个队列要绑定多个RoutingKey,需要绑定多次
举例:
data:image/s3,"s3://crabby-images/1050e/1050ecd3c6fed7cbd220fe9ed2f14f040b58d2b4" alt=""
这样一来,这两个队列绑定的交换机,会把RoutingKey为red的消息,转发给direct.queue1和direct.queue2;会把RoutingKey为blue的消息,转发给direct.queue1;会把RoutingKey为yellow的消息,转发给direct.queue2。
三、Topic交换机(定向转发)
1、什么是Topic交换机?
Topic交换机和Direct交换机一样,都是通过routingKey来指定交换机要将消息转发给哪个队列。
2、Topic交换机和Direct交换机的区别
Topic交换机在绑定队列时,routingKey可以是多个单词的列表,并以"."分割。
可以使用通配符来表示每个单词。
规则①:#代指任意个单词
规则②:*代指1个单词
举例:
data:image/s3,"s3://crabby-images/0b5ad/0b5ade1e1430cf1074c5249e0d0ad0506f62a37f" alt=""
3、案例
①案例介绍
data:image/s3,"s3://crabby-images/3b67b/3b67b8e9dcec0c6618a165a1b664c3b33251e782" alt=""
②具体操作
- 第一步:创建两个队列,topic.queue1和topic.queue2
data:image/s3,"s3://crabby-images/d2a82/d2a82bb9d46bc35807d89c3ff4dbd330262efabf" alt=""
- 第二步:创建Topic类型的交换机,叫hmall.topic
data:image/s3,"s3://crabby-images/39fb7/39fb72d6f6be1fa6b1b54bf0fb974191b8f5901b" alt=""
-
第三步:给hmall.topic交换机,绑定那两个队列,并指定每个队列的routingKey
data:image/s3,"s3://crabby-images/dd731/dd7317be9ce6cd5c0151cd10d384ecde4c264be3" alt=""
- 第四步:编写代码,向hmall.topic交换机中发送一条消息。
data:image/s3,"s3://crabby-images/291f9/291f9233519d10597d503bbe91e3f5280bd58640" alt=""
- 第五步:编写两个消费者方法,分别监听topic.queue1和topic.queue2
java
@Component //交给spring管理
public class MqListener {
@RabbitListener(queues = "topic.queue1")
public void listenTopicQueue1(String msg) throws InterruptedException {//消费者1
System.err.println("消费者1 收到了 topic.queue1的消息... :【" + msg + "】");
}
@RabbitListener(queues = "topic.queue2")
public void listenTopicQueue2(String msg) throws InterruptedException {//消费者2
System.err.println("消费者2 收到了 topic.queue2的消息... :【" + msg + "】");
}
}
- 第六步:启动项目,测试结果
java
消费者2 收到了 topic.queue2的消息... :【红色警报,由于日本排放核污水,惊险哥斯拉!】
- 第七步:分析hmall.topic交换机转发消息的过程
data:image/s3,"s3://crabby-images/46813/4681327ed3ebeaf731932d22d9394a6240eb5e52" alt=""
4、总结
data:image/s3,"s3://crabby-images/5a0d8/5a0d8bb28ca10681cfebeb98a76245374426029a" alt=""
结语
以上就是RabbitMQ中的Fanout交换机、Direct交换机、Topic交换机的全部内容,想了解更多关于RabbitMQ的知识,请关注本博主~~