前言
关于消息中间件的应用场景,小伙伴们应该都耳熟能详了吧,比如经常提到的 削峰填谷、分布式事务、异步业务处理、大数据分析 等等,分布式消息队列成为其中比较关键的桥梁,也就意味着小伙伴们得掌握相关技能;当下相对比较热门的消息中间件有RabbitMQ、Kafaka、RocketMQ、ActiveMQ等,在实际应用场景中,发现很多小伙伴和我一样都是跟着相关框架(CAP、Masstransit等)文档进行使用,实现功能,并没有关注消息队列相关知识点,总感觉缺少点精髓,所以想着就以RabbitMQ为着手点,一起学习学习相关细节。
正文
1. 简介
1.1 RabbitMQ 概要
RabbitMQ是基于Erlang语言开发的开源消息中间件,比较轻量级,广泛应用于分布式系统中存储消息、转发消息,具有高可用,高可扩性,易用性等特征。
RabbitMQ支持多种消息传递协议,默认采用的是AMQP协议,通过插件扩展的方式可以支持STOMP、MQTT、RabbitMQ Stream协议。
-
AMQP协议简单理解
AMQP:(全称:Advanced Message Queuing Protocol-是高级消息队列协议) ,是一个提供统一消息服务的应用层标准高级消息队列协议,是一种二进制协议;基于此协议的客户端与消息中间件可传递消息,并不受客户端/中间件不同产品、不同的开发语言等条件的限制。
-
核心组成部分
RabbitMQ基于AMQP实现,主要组成部分及流程如下:
上图简介:
生产者负责将消息投递到服务器中,消费者负责订阅接收消息,然后进行对应的业务处理。经过的核心组成部分如下:
生产者(Producer):负责产生消息,并将消息发送到服务器上;
消费者(Consumer):负责消息的消费,即订阅消息,然后处理相关的业务逻辑;
Message:消息:服务与应用程序之间传送的数据, 由一些属性和消息体组成,通过属性可以设置消息的优先级,延迟等高级特性 ;
服务器(Server):又称Broker ,接受客户端的连接。保证消息能够按照指定的方式进行传输; 连接(Connection) :应用程序与Broker的网络连接(TCP-IP/ 三次握手和四次挥手); Channel :虚拟连接,它是基于Connection连接建立的,几乎所有的操作都在Channel中进行,Channel是进行消息读写的通道,客户端可以建立多个Channel,每个Channel代表一个会话任务;
Virtual Host虚拟地址,用于进行逻辑隔离,一个虚拟主机可以有若干个Exchange和Queue,同一个虚拟主机里面不能有相同名字的Exchange; 交换机(Exchange) :接受消息,根据路由键投递