🌟前言
在上一节中学习了JMS消息服务与AMQP协议。了解了这两大消息传递技术,这一节就学习基于AMQP协议实现的RabbitMQ消息中间件是什么?RabbitMQ的架构图是怎样的?以及RabbitMQ中的核心组件。
🌟RabbitMQ是什么?
以下解释来源于百度百科:
RabbitMQ是实现了高级消息队列协议(AMQP)的开源消息代理软件(亦称面向消息的中间件)。RabbitMQ服务器是用Erlang语言编写的,而集群和故障转移是构建在开放电信平台框架上的。所有主要的编程语言均有与代理接口通讯的客户端库。
个人理解:
基于AMQP协议实现的消息中间件,采用Erlang语言编写。
架构图:
🌟特点
- 跨平台、多语言支持。基于AMQP协议实现。
- 支持分布式。
- 可以与SpringAMQP进行整合。
- 易于管理。提供了web管理页面用来监控和管理消息队列。
- 消息可靠性。RabbitMQ内部有消息可靠性投递机制,避免消息中途的丢失。
🌟核心组件
对于核心组件的位置,可以参照架构图。
- Broker:相当于一个MQ节点。
- Producer:生产者。创建消息并发送到Broker中。
- Consumer:消费者。监听Queue中的消息并消费。
- Message:消息。数据对象,有消息头和消息体。
- Queue:消息的载体。负责存储消息。
- Channel:信道。支持多路复用,建立在生产者与broker、broker与消费者之间的虚拟连接。
- Connection:一个连接上可以有多个Channel。
- Exchange:交换机。生产者将消息发送给交换机,交换机负责使用binding_key绑定交换机与队列。
- RoutingKey:路由键。消息的路由规则。
- Binding:通过routingkey与bingding_key的规则,绑定交换机与队列。
- Virtual Host:虚拟主机。虚拟的电脑,用来分离不同的业务逻辑模块或者环境。
🌟核心流程
- Producer创建消息并发送到Broker。
- Producer与Broker建立连接Connection。
- 在Connection中创建信道Channel。
- Producer声明一个交换机Exchange,用于接受消息Message并将它们路由到正确的Queue。
- Producer选择一个RoutingKey,用于指定Exchange与哪个Queue进行绑定。
- Producer发送消息到Exchange。
- 关闭Channel。
- 关闭Connection。
- Broker中的Exchange接收到消息后,根据RoutingKey规则路由到正确的Queue。
- Exchange与Queue通过Bingding绑定。
- Queue按照先进先出存储消息和处理消息。
- 消费者从队列中消费消息Message。
- Consumer与Broker建立连接Connection。
- 在Connection创建信道Channel。
- Consumer通过ACK机制确认并消费消息。
- Queue中删除被消费的消息。
- 关闭Channel。
- 关闭Connection。
🌟写在最后
有关于消息队列RabbitMQ基本介绍到此就结束了。在本文中对RabbitMQ的基本概念做出了介绍,并配合架构图对其核心组件进行了总结。
非常感谢大家的阅读,对于学习过程中遇到的问题,希望大家在评论区对此部分内容散发讨论,便于学到更多的知识。