镜像下载、域名解析、时间同步请点击 阿里云开源镜像站
一、什么是MQ?
消息队列(Message Queue,简称MQ),从字面意思上看,本质是个队列,FIFO先入先出,只不过队列中存放的内容是message而已。
其主要用途:不同进程Process/线程Thread之间通信。
队列是一种先进先出的结构:FIFO
把要传输的数据放在队列中。
把数据放到消息队列叫生产者
从消息队列取出消息叫做消费者
二、什么是RabbitMQ?
RabbitMQ是一套开源(MPL)的消息队列服务软件,是由 LShift 提供的一个 Advanced Message Queuing Protocol (AMQP) 的开源实现,由以高性能、健壮以及可伸缩性出名的 Erlang 写成。
RabbitMQ的特性
- 可伸缩性:集群服务
- 消息持久化:从内存持久化消息到硬盘,再从硬盘加载到内存
三、使用RabbitMQ的好处
解耦
系统A在代码中直接调用系统B和系统C的代码,如果将来D系统接入,系统A还需要修改代码,过于麻烦!
系统A可以生成一个id,然后系统B需要这个id,系统A去调用了系统B
过了段时间,系统C说也要系统A的id,那么这时接触系统B的引用,去讲id传给系统C
这时又来了系统D,系统D也要系统A的id,系统A又解除了系统C,去调用了系统D,反反复复,很麻烦
系统A的负责人觉得改来改去太麻烦了,没意思,跑路了。
过段时间,公司来了位大佬,大佬说将系统A的id,存入消息队列,谁需要谁去拿,这样系统A就不用来回改动了,完美解决了参数调用问题!
系统A不关心谁去调用id,只负责生产数据并存入消息队列,其它系统即使挂了或请求超时,也跟系统A没有任何关系
这样就实现了系统A、B、C、D之间的解耦!
异步
再来看看这种情况,系统A还是直接调用系统B、C、D
系统A:主要业务
系统B:短信业务
系统C:邮箱业务
系统D:处理后续业务
系统A下单成功后会去调用系统B,但是如果一个一个的调用,会大大的降低效率,假设每个业务执行时间100ms&