初识MQ

Posted virgosnail

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了初识MQ相关的知识,希望对你有一定的参考价值。

1. 什么是MQ?

  消息队列(Message Quene)是一种跨进程的通信机制,用于上下游传递消息

  MQ是一种非常常见的上下游“逻辑解耦+物理解耦”的消息通信服务。

  使用了MQ之后,消息发送上游只需要依赖MQ,逻辑上和物理上都不用依赖其他服务。

2. 什么时候不使用MQ?

  结论:调用方实时依赖执行结果的业务场景,请使用调用,而不是MQ

  比如:用户登录场景,登录页面调用passport服务,passport服务的执行结果直接影响登录结果,此处的“登录页面”与“passport服务”就必须使用调用关系,而不能使用MQ通信。

3. 什么时候使用MQ?

  1)数据驱动的任务依赖:多个任务执行有先后关系,且任务2依赖前面的任务1结果。任务2订阅任务1,任务1完成后发送消息到MQ,任务2接收到消息后开始执行。

  2)上游不关心下游执行结果:上游只需要产生消息即可,下游自行消费。

  3)异步返回执行时间长:回调网关+MQ

4. MQ的优劣

4.1 MQ的优势

  1)解耦

  2)数据持久化到被完全处理,规避数据丢失的风险

  3)增加灵活性和峰值处理能力

  4)MQ中的消息是有序的

  5)异步通信机制

4.2 MQ的劣势

  1)系统更复杂,多了一个MQ组件

  2)消息传递路径更长,延时会增加

  3)消息可靠性和重复性互为矛盾,消息不丢不重难以同时保证

  4)上游无法知道下游的执行结果,这一点是很致命的

 

以上是关于初识MQ的主要内容,如果未能解决你的问题,请参考以下文章

初识MQ消息队列

RabbitMQ 服务异步通信 -- 初识MQ(同步通信和异步通信MQ几种常见MQ的对比)RabbitMQ安装和介绍

RabbitMQ初识以及简单模式初步

ActiveMQ-初识MQ--主题topic

ActiveMQ-初识MQ--队列Queue

ActiveMQ-初识MQ--主题topic