简介

RabbitMQ 是一个实现了高级消息队列协议(AMQP)的开源消息代理中间件。 俗称消息队列


基本组件

  • Connection 连接. 使用MQ之前需要建立连接
  • Producer 生产者
  • Consumer 消费者
  • Broker 服务器实例 管理消息和队列
  • Message 消息 由消息头和消息体组成
  • Queue 队列。消息的存放容器,先进先出
  • Exchange 交换器。 分发消息,将消息路由给服务器中的队列
  • Channel 信道
  • Virtual Host 虚拟主机

官网

AMQP客户端

以下内容代码地址

如果对你有帮助,帮忙点个小星星star谢谢~


安装


简单模式

一个生产者,一个队列,一个消费者。Exchange不参与



工作模式

Work Queue 工作队列。处理一些不需要立即执行,比较耗时的一些任务

Work Queue 会将消息分发给不同的消费者进行处理(消费者接受到的消息是不同的),消费者接受消息的数量取决于自身处理消息的速度,可以不有效的提升性能

场景: 短信、邮件等提醒




发布订阅

Publist/Subscribe 发布订阅

生产者产生一条消息,将消息发送给交换器,交换器将消息推送给所有的消费者。消费者接受到的消息是相同的。

场景: 开放平台 开发者订阅了某个开放平台的api之后,数据有变化就会自动获取到最新的数据




路由模式

Routing

其实就是发布订阅模式的升级版。将不同消息通过路由key进行绑定,进入不同的队列,每个队列的处理不同的业务逻辑

场景: 日志系统 重要的日志,有专门的队列消费处理




主题订阅模式

Topics

在路由模式的基础上增加了通配符。可以惊醒Routing ket的模糊匹配,使得消息的分发更加灵活

但是模糊匹配相对于路由模式来讲,效率可能比较低,实际中尽量采用路由模式

通配符 ‘*’ ‘#’ *: 单个关键字 #: 多个关键字




RPC同步通信

MQ是一个异步通信的,也就是生产者发送消息之后,是不知道消费者的处理结果的(成功、失败、甚至都不知道消费者有没有处理这条消息)。

有些时候,在开发中,生产者是需要知道消费者的处理结果,然后再进行下一步任务的处理。也就是同步调用。相当于RPC(Remote Procedure Call 远程过程调用)

如下图所示,实际上有两个队列,client产生了消息之后,将消息放入队列,server端开始进行消费,消费后的结果也放入一个队列,被client处理. 整个过程,是一个线程阻塞的状态。影响性能,适用于特殊的业务场景需求。