RabbitMq简介、AMPQ协议简介

目录

相关概念介绍

生产者和消费者

队列

交换器、路由键、绑定

交换器类型

fanout

direct

topic

headers

RabbitMQ运转流程

AMQP协议介绍

AMQP生产者流转过程

AMQP消费者流转过程

AMQP命令概览


RabbitMQ是一个由erlang开发的AMQP(Advanced Message Queue )的开源实现

https://www.rabbitmq.com/

相关概念介绍

RabbitMQ整体上是一个生产者与消费者模型,主要负责接收、存储和转发消息。可以把消 息传递的过程想象成:当你将一个包裹送到邮局,邮局会暂存并最终将邮件通过邮递员送到收 件人的手上,RabbitMQ就好比由邮局、邮箱和邮递员组成的一个系统。从计算机术语层面来说, RabbitMQ模型更像是一种交换机模型。

RabbitMQ的整体模型架构如图所示。

生产者和消费者

Producer: 生产者,就是投递消息的一方。

生产者创建消息,然后发布到RabbitMQ中。

消息一般可以包含2个部分:消息体和标签 (Label)。

消息体也可以称之为payload, 在实际应用中,消息体一般是一个带有业务逻辑结构 的数据,比如一个JSON字符串。当然可以进一步对这个消息体进行序列化操作。

消息的标签用来表述这条消息,比如一个交换器的名称和一个路由键。生产者把消息交由RabbitMQ, RabbitMQ之后会根据标签把消息发送给感兴趣的消费者(Consumer)。

Consumer: 消费者,就是接收消息的一方。

消费者连接到RabbitMQ服务器,并订阅到队列上。

当消费者消费一条消息时,只是消费消息的消息体(payload)。在消息路由的过程中,消息的标签会丢弃,存入到队列中的消息只 有消息体,消费者也只会消费到消息体,也就不知道消息的生产者是谁,当然消费者也不需要 知道。

Broker: 消息中间件的服务节点。

对于RabbitMQ来说,一个RabbitMQ Broker可以简单地看作一个RabbitMQ服务节点, 或者RabbitMQ服务实例。大多数情况下也可以将一个RabbitMQ Broker看作一台RabbitMQ 服务器。

图展示了生产者将消息存入RabbitMQ Broker, 以及消费者从Broker中消费数据的整 个流程。

首先生产者将业务方数据进行可能的包装,之后封装成消息,发送(AMQP协议里这个动 作对应的命令为Basic.Publish)到Broker中。消费者订阅并接收消息(AMQP协议里这个动作对应的命令为Basic.Consume或者Basic.Get),经过可能的解包处理得到原始的数据, 之后再进行业务处理逻辑。

这个业务处理逻辑并不一定需要和接收消息的逻辑使用同一个线程。 消费者进程可以使用一个线程去接收消息,存入到内存中,比如使用Java中的BlockingQueue。 业务处理逻辑使用另一个线程从内存中读取数据,这样可以将应用进一步解耦,提高整个应用 的处理效率。

队列

Queue: 队列,是RabbitMQ的内部对象,用于存储消息。参考图, 队列可以用图表示。

RabbitMQ中消息都只能存储在队列中,这一点和Kafka这种消息中间件相反。Kafka将消 息存储在topic (主题)这个逻辑层面,而相对应的队列逻辑只是topic实际存储文件中的位移 标识。RabbitMQ的生产者生产消息并最终投递到队列中,消费者可以从队列中获取消息并消费。

多个消费者可以订阅同一个队列,这时队列中的消息会被平均分摊(Round-Robin, 即轮询) 给多个消费者进行处理,而不是每个消费者都收到所有的消息并处理,如图所示。

RabbitMQ不支持队列层面的广播消费,如果需要广播消费,需要在其上进行二次开发,处理逻辑会变得异常复杂,同时也不建议这么做。

交换器、路由键、绑定

Exchange: 交换器。在图中我们暂时可以理解成生产者将消息投递到队列中,实际上 这个在RabbitMQ中不会发生。

真实情况是,生产者将消息发送到Exchange (交换器,通常也 可以用大写的"X"来表示),由交换器将消息路由到一个或者多个队列中。如果路由不到,或 许会返回给生产者,或许直接丢弃。这里可以将RabbitMQ中的交换器看作一个简单的实体, 更多的细节会在后面的章节中有所涉及。

交换器的具体示意图如图所示。

<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值