RabbitMQ(Rabbit Message Queue)是一个开源的消息队列中间件,它实现了高级消息队列协议(AMQP)并提供可靠的消息传递机制。RabbitMQ 在分布式系统中广泛用于消息传递和事件驱动的架构。以下是一些 RabbitMQ 的重要知识点:
消息队列基本概念:
生产者(Producer):生成消息并将其发送到消息队列。
消费者(Consumer):从消息队列接收并处理消息。
消息队列(Queue):消息的缓冲区,消息在队列中排队等待被消费。
交换机(Exchange):将消息路由到一个或多个队列的规则引擎。
绑定(Binding):规定了交换机和队列之间的关系,决定了消息如何被路由。
AMQP:高级消息队列协议(AMQP)是一种网络协议,定义了消息传递的标准。RabbitMQ 使用 AMQP 作为通信协议。
消息持久化:RabbitMQ 支持消息的持久化,这意味着消息可以在服务器重启后仍然可用。这对于确保消息不会丢失很重要。
虚拟主机(Virtual Host):RabbitMQ 允许在单个物理服务器上创建多个虚拟主机,每个虚拟主机相互隔离,拥有自己的用户权限、交换机和队列。
消息确认(Acknowledgement):消费者可以向服务器确认已经处理了某个消息,确保消息不会被重复处理。
消息路由:RabbitMQ 使用交换机将消息路由到一个或多个队列,可以通过不同类型的交换机(直连、主题、扇出等)