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

相关推荐
ak啊13 分钟前
多智能体协同模式:五种核心架构详解
架构
IT枫斗者20 分钟前
构建具有执行功能的 AI Agent:基于工作记忆的任务规划与元认知监控架构
android·前端·vue.js·spring boot·后端·架构
迷藏49426 分钟前
**发散创新:基于角色与属性的混合权限模型在微服务架构中的实战落地**在现代分布式系统中,
java·python·微服务·云原生·架构
WindrunnerMax35 分钟前
从零实现富文本编辑器#13-React非编辑节点的内容渲染
前端·架构·github
ssshooter37 分钟前
Tauri 应用苹果签名踩坑实录
前端·架构·全栈
Wect43 分钟前
JS手撕:手写Koa中间件与Promise核心特性
前端·javascript·面试
张元清1 小时前
React 文件处理:上传、拖放区与对象 URL
前端·javascript·面试
刘~浪地球1 小时前
消息队列--RabbitMQ 高可用集群部署
分布式·rabbitmq·ruby
未秃头的程序猿1 小时前
🚀 从“单机崩盘”到“集群稳如狗”:Redis 高可用避坑指南(保姆级实战)
redis·后端·面试
前进的李工1 小时前
智能Agent实战指南:从入门到精通(工具)
开发语言·人工智能·架构·langchain·agent·tool·agentexecutor