欢迎您访问365答案网,请分享给你的朋友!
生活常识 学习资料

RabbitMQ交换器

时间:2023-06-22

RabbitMQ交换器类型有fanout、direct、topic、headers

fanout

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

direct

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

topic

direct 类型的交换器路由规则是完全匹配 BindingKey和RoutingKey ,但是这种严格的匹配方式在很多情况下不能满足实际业务的需求.topic 类型的交换器在匹配规则上进行了扩展,它与 direct类型的交换器相似,也是将消息路由到 BindingKey和RoutingKey相匹配的队列中,但这里的匹配规则有些不同,它约定:*RoutingKey 为一个点号"."分隔的字符串(被点号"."分隔开的每 段独立的字符串称为一个单词),如"com.rabbi.q.client"、"java、util.concurrent"、"com.hidden.client";*BindingKe RoutingKey 一样也是点号"."分隔的字符串;*BindingKey 中可以存在两种特殊字符串"*"和"#",用于做模糊匹配,其中"#"用于匹配一个单词,"#"用于匹配多规格单词.

headers

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

Copyright © 2016-2020 www.365daan.com All Rights Reserved. 365答案网 版权所有 备案号:

部分内容来自互联网,版权归原作者所有,如有冒犯请联系我们,我们将在三个工作时内妥善处理。