RabbitMQ中支持多种类型的交换机

RabbitMQ中支持多种类型的交换机(Exchange)

其中每种类型都有其特定的路由逻辑,用于将消息路由到一个或多个队列中。以下是RabbitMQ中常见的四种交换机类型:

  1. 直连交换机(Direct Exchange)
  • 特点:Direct交换机根据消息的routing key将消息路由到特定的队列。一个队列可以绑定多个routing key,但一个routing key只能被一个队列绑定(除非存在多个相同的routing
    key绑定到不同队列的情况).如果消息的routing key与队列的routing key完全匹配,则该消息会被路由到该队列。
  • 应用场景:当需要根据不同的routing key将消息分发到不同的队列时,可以使用Direct交换机。例如,在订单处理系统中,可以根据订单类型(如"普通订单"、"加急订单"等)作为routing
    key,将订单消息分发到不同的处理队列中。
  • 绑定规则:使用完全匹配的绑定键。
  1. 扇出交换机(Fanout Exchange)
  • 特点:Fanout交换机将接收到的所有消息广播到所有与之绑定的队列中。它不关心消息的routing key,因为所有消息都会被发送到所有绑定的队列。
  • 应用场景:当需要将消息广播到多个消费者时,可以使用Fanout交换机。例如,在日志系统中,可以将日志消息发送到Fanout交换机,然后所有绑定到该交换机的队列都能接收到日志消息,实现日志的分布式存储和处理。
  • 特点:消息会被转发到与该交换机绑定的所有队列上,类似于子网广播。
  1. 主题交换机(Topic Exchange)
  • 特点:根据消息的路由键和通配符模式进行匹配,将消息路由到一个或多个队列。
  • 路由键和绑定键都支持通配符"*"(表示一个词)和"#"(表示一个或多个词)。
  • 应用场景:当需要根据复杂的路由规则将消息分发到不同的队列时,可以使用Topic交换机。例如,在新闻系统中,可以根据新闻的分类(如"国际.政治"、"国内.经济"等)作为routing
    key,然后设置不同的binding key来匹配不同的新闻分类,实现新闻的分类处理。
  • 绑定规则:使用模式匹配的绑定键,例如*.info#.error
  1. 头部交换机(Headers Exchange)
  • 特点:不处理路由键,而是根据消息的头部信息(Header)进行匹配,将消息路由到匹配的队列。
  • 应用场景:适用于需要根据消息的特定属性进行路由的场景。
  • 绑定规则:在绑定队列和交换机时,可以指定一组键值对;消息的头部信息中包含这些键值对时,消息会被路由到该队列。
相关推荐
未若君雅裁2 小时前
RabbitMQ 消息可靠性:生产者确认、持久化、消费者ACK与幂等消费
分布式·微服务·rabbitmq
小江的记录本1 天前
【Kafka核心】Kafka 3.0+ KRaft模式(替代ZooKeeper)核心原理与优势
java·数据库·分布式·后端·zookeeper·kafka·rabbitmq
phltxy1 天前
RabbitMQ SpringBoot消息队列与应用间通信
spring boot·rabbitmq·java-rabbitmq
过期动态1 天前
【RabbitMQ高级篇】生产者可靠性、MQ可靠性、消费者可靠性以及延迟队列的实现
java·数据结构·分布式·算法·rabbitmq·ruby
phltxy2 天前
RabbitMQ 工作模式与Java原生客户端案例
java·rabbitmq·java-rabbitmq
装不满的克莱因瓶2 天前
【项目亮点四】支付订单超时处理与状态补偿机制设计
java·开发语言·后端·rabbitmq·消息中间件
开开心心就好2 天前
免费无广告的批量卸载与系统清理工具
linux·服务器·网络·智能手机·rabbitmq·excel·memcached
Devin~Y3 天前
大厂Java面试实录:Spring Boot微服务 + Redis缓存 + Kafka消息队列 + Prometheus链路追踪 + RAG向量检索
java·spring boot·redis·spring cloud·kafka·rabbitmq·spring mvc
phltxy3 天前
RabbitMQ 入门与安装
分布式·rabbitmq
逻极3 天前
RabbitMQ 从入门到精通:构建高可用、高性能的消息中间件系统
分布式·rabbitmq·消息中间件