【消息队列】RabbitMQ的基本架构?

1、RabbitMQ的基本架构是什么?包括哪些核心组件?

RabbitMQ的架构其实很像我们现实生活中的快递物流系统。
有6个关键组件组成:
1、Producer(生产者) :就是发件人 ,负责产生消息并发送给RabbitMQ
2、Exchange(交换机) :就是快递分拣中心 ,是RabbitMQ中最核心的设计!生产者发来的包裹不会直接进队列,而是先发给交换机 。交换机根据包裹上的地址(Routing Key)路由键 ,决定把它扔进哪个队列。
3、Queue(队列):就是快递仓库 。消息最终存放的地方,等待被取走。

一个消息可以被拷贝到多个队列中,但是一个队列中的消息只能被消费一次。
4、Binding(绑定):就是分拣规则 。告诉交换机:如果是发往北京的包裹,请扔进A队列。

它把Exchange和Queue连接起来。
5、Consumer(消费者) :就是收件人 。从队列中取消息并处理。

6、Virtual Host(虚拟主机):就是独立租户 。这就好比一台服务器上跑了多个MySQL数据库(DB1、DB2),VHost之间是完全隔离的,互不影响。

通常区分不同的业务线,比如/order给订单组用,/user给用户组用。

2、为什么要有Exchange?直接发给Queue不行吗?

这是很多人的疑问,我刚开始也一样,有这个问题,下面看完你应该会明白的。

普通MQ,如ActiveMQ早期,确实点对点,直接发送给队列。

而RabbitMQ的设计哲学就是解耦 ,没错,解耦!

生产者不需要知道消息发给谁 ,只需要知道这类消息是什么类型的 就好了。

如果你的业务变了,比如注册成功的消息,原本只需要发邮件(QueueA),现在需要加一个发短信(QueueB)
如果没有Exchange,得改代码,让生产者发两份。
有了Exchange ,生产者代码一行不用动,只需要在后台配置一下,把Exchange绑定到新的QueueB上就行了。灵活路由 的牛B之处就体现出来了。

相关推荐
Msshu1237 小时前
Type-C 多协议快充诱骗电压芯片XSP28 芯片脚耐压高达21V 电路简单 性价比高
mongodb·zookeeper·rabbitmq·flume·memcache
NAGNIP8 小时前
一文搞懂机器学习中的特征降维!
算法·面试
NAGNIP8 小时前
一文搞懂机器学习中的特征构造!
算法·面试
Java 码农8 小时前
RabbitMQ集群部署方案及配置指南03
java·python·rabbitmq
源心锁9 小时前
丧心病狂!在浏览器全天候记录用户行为排障
前端·架构
Tony Bai11 小时前
【分布式系统】03 复制(上):“权威中心”的秩序 —— 主从架构、一致性与权衡
大数据·数据库·分布式·架构
AIagenttest11 小时前
2026年智能招聘管理系统测评:从流程协同到算力执行的架构跨越
架构
Mr_sun.13 小时前
微服务框架课程
微服务·云原生·架构
伟兮13 小时前
iOS日志系统设计
架构