【消息队列】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之处就体现出来了。

相关推荐
vx-bot5556665 小时前
企业微信接口在多租户SaaS平台中的集成架构与数据隔离实践
大数据·架构·企业微信
血小板要健康6 小时前
Java基础常见面试题复习合集1
java·开发语言·经验分享·笔记·面试·学习方法
桌面运维家8 小时前
vDisk流量怎么精细化分配?VOI/IDV架构配置指南
架构
zuozewei8 小时前
7D-AI系列:DeepSeek Engram 架构代码分析
人工智能·架构
徐礼昭|商派软件市场负责人8 小时前
Moltbot,也就是OpenClaw的底层架构解析
架构
国科安芯8 小时前
面向星载芯片原子钟的RISC-V架构MCU抗辐照特性研究及可靠性分析
单片机·嵌入式硬件·架构·制造·risc-v·pcb工艺·安全性测试
小北的AI科技分享9 小时前
人工智能大模型搭建:数据、算法与算力的三大基石
架构·模型·搭建
OceanBase数据库官方博客9 小时前
爱奇艺基于OceanBase实现百亿级卡券业务的“单库双擎”架构升级
数据库·架构·oceanbase·分布式数据库
AC赳赳老秦9 小时前
DeepSeek 辅助科研项目申报:可行性报告与经费预算框架的智能化撰写指南
数据库·人工智能·科技·mongodb·ui·rabbitmq·deepseek
一品威客网9 小时前
App 软件制作的核心技术与方法:从架构到落地
架构