rabbitmq - 相关概念介绍

278 阅读2分钟

1.生产者消费者

Producer 生产者

Consumer 消费者

Broker 消息中间件的服务节点

2.队列

Queue 队列是RabbitMq的内部对象,用于存储消息。

3.交换器、路由键、绑定

Exchange 交换器

生产者将消息发送到Exchange,由交换器将消息路由到一个或者多个队列中。如果路由不到,或许会返回给生产者,或者直接丢掉。

常用的四种类型

  • fanout
    它会把所有发送到该交换器的消息路由到所有与该交换器绑定的队列中

  • direct
    完全匹配 它会把消息路由到那些BindingKey 和 RoutingKey 完全匹配的队列中

  • topic
    模糊匹配 它在direct的基础上做了扩展,支持更灵活的路由规则匹配方式。

  • headers
    headers 类型的交换器不依赖于路由键的匹配规则来路由消息,而是根据发送的消息内容中的headers属性进行匹配。在绑定队列和交换器时制定一组键值对,当发送消息到交换器时。RabbitMq会获取到消息的headers(也是一个键值对形式),对比其中的键值对是否完全匹配队列和交换器绑定时指定的键值对。如果完全匹配则消息会路由到该队列,否则不会路由到该队列。headers类型的交换器性能会很差,而且也不实用,基本上不会看到它的存在

RoutingKey 路由键

生产者将消息发送给交换器的时候,一般会指定一个RoutingKey,用来指定这个消息的路由规则而这个Routking Key需要与交换器类型和绑定键(BindingKey)联合使用才能最终生效
在交换器类型和绑定键(BindingKey)固定的情况下,生产者可以在发送消息给交换器时,通过指定RoutingKey来决定消息流向哪里

Binding 绑定
RabbitMq中通过绑定将交换器与队列关联起来,在绑定的时候一般会指定一个绑定键(BindingKey),这样RabbitMq就知道如何正确的将消息路由到队列了。

生产者将消息发送给交换器时,需要一个RoutingKey,当BindingKey和RoutingKey相匹时,消息会被路由
到对应的队列中,即使一个BindingKey被一个交换器和多个队列绑定。BindingKey并不是在所有的场景下
都生效,取决于不同类型交换器的路由规则