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

相关推荐
牛奶7 小时前
Vue 基础理论 & API 使用
前端·vue.js·面试
牛奶7 小时前
Vue 底层原理 & 新特性
前端·vue.js·面试
NAGNIP8 小时前
一文搞懂深度学习中的通用逼近定理!
人工智能·算法·面试
sunny_9 小时前
⚡️ vite-plugin-oxc:从 Babel 到 Oxc,我为 Vite 写了一个高性能编译插件
前端·webpack·架构
青青家的小灰灰13 小时前
深入理解事件循环:异步编程的基石
前端·javascript·面试
兆子龙14 小时前
模块联邦(Module Federation)详解:从概念到手把手 Demo
前端·架构
程序员清风15 小时前
程序员兼职必看:靠谱软件外包平台挑选指南与避坑清单!
java·后端·面试
Bigger16 小时前
告别版本焦虑:如何为 Hugo 项目定制专属构建环境
前端·架构·go
UrbanJazzerati19 小时前
Vue3 父子组件通信完全指南
前端·面试
UrbanJazzerati20 小时前
Vue 3 纯小白快速入门指南
前端·面试