RabbitMQ-工作模式
2020-06-06 07:05
246 查看
文章目录
概述
RabbitMQ有以下几种工作模式
- Work Queues 工作队列
- Publish/Subscribe 发布订阅
- Routing 路由
- Topics 通配符
- Header Header转发器
- RPC 远程过程调用
1. Work Queues
工作队列模式
- 一个生产者将消息发给一个队列
- 多个消息者共同监听一个队列的消息
- 消息不能被重复消费
- rabbit采用轮询的方式将消息是平均发送给消费者
2. Publish/subscribe
发布订阅模式
- 一个生产者将消息发给交换机
- 与交换机绑定的有多个队列,每个消费者监听自己的队列
- 生产者将消息发给交换机,由交换机将消息转发到绑定此交换机的每个队列,每个绑定交换机的队列都将接收到消息
- 如果消息发给没有绑定队列的交换机上消息将丢失
区别
- publish可以定义一个交换机绑定多个队列,一个消息可以发送给多个队列
- work queues无需定义交换机,一个消息一次只能发送给一个队列
- publish功能更强大,也可以将多个消费者监听同一个队列实现work queues的功能
3.Routing
路由模式
- 一个交换机绑定多个队列,每个队列设置routingkey,并且一个队列可以设置多个routingkey
- 每个消费者监听自己的队列
- 生产者将消息发给交换机,发送时需要指定routingkey的值,交换机来判断routingkey的值和哪个队列的routingkey相等,相等则将消息转发给该队列
4.Topics
通配符模式
- 大概规则同路由模式
- 匹配规则如下
符号# : 匹配0个或者多个词,每个词用 . 分割 inform.# : inform.sms、inform.sms.email inform.#.email.# :中间是email的都可以 符号* : 只能匹配一个词 inform.* : inform.sms
5.Header
header模式
- 与routing区别是没有routingkey,而是用header中的key/value对匹配队列
代码例子
- 队列与交换机绑定时
- 通知时:该消息给到交换机中有这些属性的队列
6. RPC
RPC客户端远程调用服务端
使用MQ可以实现RPC的异步调用,基于Direct交换机实现,流程如下
- 客户端既是生产者又是消费者,向RPC请求队列发送RPC调用消息,同时监听RPC响应队列
- 服务端监听RPC请求队列的消息,收到消息后执行服务端的方法,得到方法返回的结果
- 服务端将RPC方法的结果发送到RPC响应队列
A
相关文章推荐
- rabbitmq 消息队列工作模式
- 05-05_RabbitMQ_工作模式_主题模式
- 05-04_RabbitMQ_工作模式_路由Routing模式
- rabbitmq的五种工作模式
- 05-03_RabbitMQ_工作模式_发布PUB-订阅SUB模式
- RabbitMQ的工作模式之五主题(Topic)模式
- RabbitMQ的工作模式
- 05-02_RabbitMQ_工作模式_WorkQueue工作队列模式
- RabbitMQ Java 工作模式
- RabbitMQ的工作模式之四路由(Routing)模式
- RabbitMQ学习:RabbitMQ的六种工作模式终结篇(四)
- RabbitMQ的几种工作模式
- RabbitMQ的工作模式之三发布/订阅(Publish/Subscribe)模式
- RabbitMQ的工作模式之二工作(Work)模式
- RabbitMQ的工作模式之一简单(Simple)模式
- RabbitMQ工作模式
- rabbitMQ的工作模式
- RabbitMQ的Docker安装和6大工作模式以及在SpringBoot整合
- python使用rabbitMQ介绍二(工作队列模式)
- RabbitMQ 6种工作模式