Rabbit 交换机四种类型

Rabbit 交换机四种类型

        RabbitMQ 常用的交换器类型有fanoutdirecttopicheaders 这四种。AMQP 协议里还提到另外两种类型: System自定义


目录

Rabbit 交换机四种类型

fanout (广播)

direct

topic

headers


fanout

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

fanout 就是传说中的广播模型,只要是连接在频道内的所有用户,都能在生产者发送消息后接收到消息。

详细内容请看我的 另一篇博客 RabbitMQ->fanout(广播模型)

 

direct

direct 类型的交换器路由规则也很简单,它会把消息路由到那些 BindingKey 和 RoutingKey 完全匹配的队列中。

详细讲解以及代码实现可 参考我得另一篇博客 RabbitMQ-HelloWorld

 

topic

前面讲到direct 类型的交换器路由规则是完全匹配BindingKey 和RoutingKey ,但是这种严格的匹配方式在很多情况下不能满足实际业务的需求。topic 类型的交换器在匹配规则上进行了扩展,它与direct 类型的交换器相似,也是将消息路由到BindingKey 和RoutingKey 相匹配的队列中,但这里的匹配规则有些不同,它约定:

  1. RoutingKey 为一个点号"."分隔的字符串(被点号"."分隔开的每一段独立的字符串成为一个单词),如"com.rabbitmq.client"、"java.util.concurrent"、"com.hidden.client"

  2. BindingKey 和 RoutingKey 一样也是点号"."分割的字符串

  3. BindingKey 中可以存在两种特殊的字符串""、"#",用于做模糊匹配,其中"#"用于匹配一个单词,""用于匹配多规格单词(可以是零个)。

headers

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

 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值