RabbitMQ 交换器

RabbitMQ 交换器

direct

如上图所示,两个队列绑定到了direct交换器上,第一个队列绑定的 binding keyorange ,第二个队列有两个绑定,分别是 blackgreen

如上图所示,用相同的 binding key 绑定到多个队列上是完全OK的。

上图为日志系统所使用的direct交换器场景。

direct交换器的路由算法很简单,一条消息将会进入 binding key (队列的绑定) 和消息的 routing key 完全匹配的队列。

如果路由键完全匹配的话,消息就被投递到对应的队列。

fanout

消息通信模式:当你发送一条消息到 fanout 交换器时,它会把消息投递给 所有 附加在此交换器上的队列。这允许你对单条消息做不同方式的反应。

发送时需要提供 routing_key ,但是对于 fanout 交换器,它的值将被忽略。

topic

这类交换器允许你实现有趣的消息通信场景,它使得来自不同源头的消息能够到达同一个队列。

  • 单个 "." 把路由键分为几部分
  • "*" 匹配特定位置的任意文本。
  • 为了实现匹配所有规则,你可以实用 "#" 字符

headers 弃用

header交换器和direct交换器完全一致,但性能会差很多。因此不太实用,几乎再也用不到了。

相关推荐
青云交2 小时前
Java 大视界 -- 基于 Java 的大数据分布式数据库架构设计与实践(125)
java·大数据·分布式·分布式数据库·架构设计·数据处理·高可用性
犀思云2 小时前
领先AI企业经验谈:探究AI分布式推理网络架构实践
人工智能·分布式·ai网络
MarkHD3 小时前
第二十五天 实践分布式数据管理,实现数据在多设备间的同步
分布式·wpf
种豆走天下3 小时前
用 Kafka、RabbitMQ、RocketMQ、Redis 、Nginx等组件优化
kafka·rabbitmq·rocketmq
不爱学习的小枫4 小时前
spark常见的submit参数
大数据·分布式·spark
@TangXin5 小时前
RabbitMQ容器部署
rabbitmq
种豆走天下15 小时前
Zookeeper学习
分布式·学习·zookeeper
WeiLai111216 小时前
面试基础--高并发高可用架构深度实践:降级熔断(Hystrix vs Sentinel)核心原理与源码解析
java·分布式·后端·hystrix·面试·架构·sentinel
Java码农也是农18 小时前
RabbitMQ使用延迟消息
java·rabbitmq·延迟消息
恋红尘19 小时前
RabbitMq
数据库·分布式·rabbitmq