一. rabbitmq工作原理
下图是RabbitMQ的基本结构:
组成部分说明如下:
Broker :消息队列服务进程,此进程包括两个部分:Exchange和Queue。
Exchange :消息队列交换机,按一定的规则将消息路由转发到某个队列,对消息进行过虑。
Queue :消息队列,存储消息的队列,消息到达队列并转发给指定的消费方。
Producer :消息生产者,即生产方客户端,生产方客户端将消息发送到MQ。
Consumer :消息消费者,即消费方客户端,接收MQ转发的消息。
connection: mq连接
Channel:会话,每次生产者或消费者与rabbitmq的连通发送消息就是一次会话
消息发布接收流程:
-----发送消息-----
1、生产者和Broker建立TCP连接。
2、生产者和Broker建立通道。
3、生产者通过通道消息发送给Broker,由Exchange将消息进行转发。
4、Exchange将消息转发到指定的Queue(队列)
----接收消息-----
1、消费者和Broker建立TCP连接
2、消费者和Broker建立通道
3、消费者监听指定的Queue(队列)
4、当有消息到达Queue时Broker默认将消息推送给消费者。
5、消费者接收到消息。
二. 常用的几种工作模式
1、Work queues 工作队列模式
2、Publish/Subscribe 发布订阅模式
3、Routing 路由模式
4、Topics 通配符模式
5、Header
6、RPC
三. 开发流程
1、发送端操作流程
1)创建连接
2)创建通道
3)声明队列
4)发送消息
2、接收端
1)创建连接
2)创建通道
3)声明队列
4)监听队列
5)接收消息
6 )ack回复
四. 各种模式介绍
1、Work queues 工作队列模式
工作队列模式结构:
一个生产者,一个队列,以及一个或多个消费者同时绑定同一队列.
工作方式:
1、一条消息只会被一个消费者接收;
2、rabbit采用轮询的方式将消息是平均发送给消费者的;
3、消费者在处理完某条消息后,才会收到下一条消息。
适用场景:
对于 任务过重或任务较多情况使用工作队列可以提高任务处理的速度。
2、Publish/Subscribe 发布订阅模式
发布订阅模式结构:
一个生产者,一个交换机,一个队列,以及一个或多个消费者同时绑定同一队列.
与工作队列相比在生产者和队列之间多了一个交换机,队列与交换机绑定
工作方式:
1、生产者将消息发给交换机exchange,
2、交换机将消息转发到绑定此交换机的每个队列(每个队列都会收到消息)
3、在队列中的消息同样只能被消费一次
适用场景:
发布消息后需要通知全部消费者.
3、Routing 路由模式
路由模式结构:
一个生产者,一个交换机,一个队列,以及一个或多个消费者同时绑定同一队列.
与发布订阅模式的区别:队列与交换机绑定时会指定routingKey
工作方式:
1、一条消息只会被一个消费者接收;
2、生产者发布消息时会指定routingKey,由交换机根据routingkey来转发消息到指定的队列;
3、消费者在处理完某条消息后,才会收到下一条消息。
适用场景:
生产者需要根据不同情况区分发送消息到指定消费者
4、Topics 通配符模式
结构:
一个生产者,一个交换机,一个队列,以及一个或多个消费者同时绑定同一队列.
与路由模式的区别:routingKey支持带通配符.更加灵活,不需要针对每一种情况配置routingKey
工作方式:
1、一条消息只会被一个消费者接收;
2、生产者发布消息时会指定routingKey,由交换机根据routingkey来转发消息到指定的队列;
3、消费者在处理完某条消息后,才会收到下一条消息。
适用场景:
生产者需要根据不同情况区分发送消息到指定消费者
5、Header
header模式与routing不同的地方在于,header模式取消routingkey,使用header中的 key/value(键值对)匹配队列。
6、RPC
RPC即客户端远程调用服务端的方法 ,使用MQ可以实现RPC的异步调用,基于Direct交换机实现,流程如下:
1、客户端即是生产者就是消费者,向RPC请求队列发送RPC调用消息,同时监听RPC响应队列。
2、服务端监听RPC请求队列的消息,收到消息后执行服务端的方法,得到方法返回的结果
3、服务端将RPC方法 的结果发送到RPC响应队列
4、客户端(RPC调用方)监听RPC响应队列,接收到RPC调用结果。
最后附上代码地址,代码练习部分在 test-rabbitmq工程
https://gitee.com/chenhaotao1992/sc-multipl-project.git