MQ
MQ(message quene):翻译为消息队列,通过典型的生产者和消费者模式,生产者不断向消息队列中生产消息,消费者不断从队列中获取消息。因为消息的生产和消费都是异步的,而且只关心消息的发送和接收,没有业务逻辑的侵入,轻松实现系统之间的解耦
RabbitMQ
RabbitMQ是使用Erlang语言开发的开源消息队列系统,基于AMQP协议来实现。AMQP的主要特征是面向消息、队列、路由(点对点和发布/订阅)、可靠、安全。AMQP协议更多用在企业系统内对数据的一致性、稳定性和可靠性要求很高的场景,对性能和吞吐量的要求在其次(Kafka高性能,适用大数据)
——windows下载安装
- (个人)下载地址:https://download.csdn.net/download/weixin_43842853/12854321
- 启动:
\RabbitMQ Server\rabbitmq_server-3.8.0\sbin\rabbitmq-server.bat
- 访问:http://localhost:15672/(通信端口5672)
- (默认)账号&密码:guest / guest
1. 重要概念
- Exchange:消息交换机,它指定消息按什么规则,路由到哪个队列。
- Queue:消息队列载体,每个消息都会被投入到一个或多个队列。
- Binding:绑定, 它的作用就是把exchange和queue按照路由规则绑定起来。
- Routing Key:路由关键字, exchange根据这个关键字进行消息投递。
- vhost:虚拟主机, 一个broker里可以开设多个vhost, 用作不同用户的权限分离。
- producer:消息生产者,就是投递消息的程序。
- consumer:消息消费者, 就是接受消息的程序。
- channel:消息通道,在客户端的每个连接里,可建立多个channel,
每个channel代表一个会话任务。
2. 结构图
3. 使用过程
- 客户端连接到消息队列服务器, 打开一个channel。
- 客户端声明一个exchange, 并设置相关属性。
- 客户端声明一个queue, 并设置相关属性。
- 客户端使用routing key, 在exchange和queue之间建立好绑定关系。
- 客户端投递消息到exchange。
exchange接收到消息后, 就根据消息的key和已经设置的binding, 进行消息路由,将消息投递到一个或多个队列里。
交换机的创建取决于消费者是否消费
4. 消息可靠性
- Message acknowledgment:消息回执
应答机制下:收到回执才删除消息;未收到回执而连接断开,消息会转给其他消费者。
应答机制下:忘记回执会导致消息堆积,业务重复处理
采用非应答机制可以提升队列处理效率 - Message durability:消息持久化
可以避免绝大部分的消息丢失,如服务重启。 采用非持久化机制可以提升队列处理效率- (1) exchange持久化,在声明时指定durable=>1
- (2) queue持久化,在声明时指定durable=>1
- (3) 消息持久化,在投递时指定deivery_mode=>2(1是非持久化)
- Prefetch count:每次发送给消费者消息数量, 默认1, 实践采用2
5. 交换机类型
Direct(直连):把消息路由到那些BindingKey和RoutingKey完全匹配的队列中
- 适用场景:有优先级的任务,根据任务的优先级把消息发送到对应的队列,这样可以指派更多的资源去处理高优先级的队列
Fanout(扇形):把所有发送到该交换器的消息路由到所有与该交换器绑定的队列中
Topic(主题)
Headers(首部):不依赖路由键的匹配规则来路由消息,而是根据发送的消息内容中的headers属性进行匹配(基本不用)