Rabbit MQ

如果对您有帮助或者解决了您的问题, 就帮我点个赞或者评论关注支持吧, 您的鼓励是我写博客的最大支持, 感谢!

1. 核心概念

整体上是一个生产者与消费者模型,主要负责接收、存储和转发消息

Rabbit MQ

1.1 生产者

生产消息的一方

消息一般由 2 部分组成:消息头和 消息体。消息头包括 routing-key(路由键)、priority(相对于其他消息的优先权)、delivery-mode(指出该消息可能需要持久性存储)

1.2 消费者

消费消息的一方

1.3 交换器

交换器类型:direct(默认),fanout, topic, 和 headers

  • direct
    • 把消息路由到那些 Bindingkey 与 RoutingKey 完全匹配的 Queue 中
  • fanout
    • 把所有发送到该Exchange的消息路由到所有与它绑定的Queue中
  • topic
    • 类似于数据库like

Rabbit MQ

  • headers不推荐

生产者将消息发给交换器的时候,一般会指定一个 RoutingKey(路由键),用来指定这个消息的路由规则,而这个 RoutingKey 需要与交换器类型和绑定键(BindingKey)联合使用才能最终生效。

Rabbit MQ 

1.4 消息队列

 消息的容器,用来保存消息直到发送给消费者

1.5 Broker

Rabbit MQ