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之处就体现出来了。
