教程说明
- 本系列教程目录大纲:《RabbitMQ系列教程-目录大纲》
- 本系列教程配套代码:https://gitee.com/Horizon1024/rabbitmt.git(码云地址)
RabbitMQ工作模式之Pub/Sub发布订阅模式
4.3.1 简介
在发布订阅模式中,Producer
发送消息到指定的交换机(Exchange
)中,由Exchange
绑定不同的Queues
,消费者依旧监听这些队列进行消费(work
模式使用的是默认的交换机,空字符串""
)
tips:交换机(Exchange)只负责将消息转发到绑定的队列(Queues)中,不会存储消息,如果Exchange没有绑定Queues或者Exchange不能将消息路由到指定的Queues中时,此消息将会丢失;
一个Exchange可以有direct
、topic
、headers
、fanout
四种类型,不同类型的Exchange具备不同的消息路由功能,Pub/Sub
模式则重点强调的是fanout
类型的Exchange
交换模式,Pub/Sub
模式也叫分列模式;
Pub/Sub模式官网介绍:https://www.rabbitmq.com/tutorials/tutorial-four-java.html
4.3.2 生产者
运行完毕之后,查看RabbitMQ UI面板,发现多了一个Exchange(test_fanout)和两个Queues(test_fanout_queue1
、test_fanout_queue2
)
4.3.3 消费者1
4.3.4 消费者2
4.3.5 Pub/Sub模式小结
在Pub/Sub
模式下(Exchange
类型为Fanout
,也叫分列模式),消息首先被发送到Exchange
,由Exchange
路由到绑定的Queue
中,类似于我们微信群,有什么事在群里面发送一下,群里面的人都能看得到;这样就不需要每个人单独发送消息了;
需要注意的两点:
1、work、simple也会有交换机,他们使用的是默认的交换机
2、Exchange还可以绑定到另一个Exchange上
Pub/Sub
模式重点强调的是Fanout
类型的Exchange
交换模式,很多人也把Pub/Sub
模式称为分列模式
或者Fanout
模式;
下一篇:《RabbitMQ系列教程-第四章-04-RabbitMQ工作模式之Routing路由模式》