1. 什么是MQ?
消息队列(MQ),是一种应用程序对应用程序的通信方法。应用程序通过写和检索出入列队的针对应用程序的数据(消息)来通信,而无需专用连接来链接它们。 消息传递指的是程序之间通过在消息中发送数据进行通信,而不是通过直接调用彼此来通信,直接调用通常是用于诸如远程过程调用的技术。排队指的是应用程序通过队列来通信。队列的使用除去了接收和发送应用程序同时执行的要求。
2. 为什么要用消息队列?
a:异步处理。 程序中的非依赖关系的功能,如日志的收集,直接将需要处理的日志,丢到消息队列中。 b:系统解耦。 将直接调用,变为A->mq,mq->B。A,B服务是相互独立的,减少相互的影响 c:流量消峰。 当流量比较大的时候,如果下游系统无法处理瞬间的大流量,会导致系统的cpu等资源紧张,进而拖垮整个系统。使用消息队列,可以将上游瞬间的流量产生的消息放在mq,消费者可以根据自己的消费能力处理队列中的数据,这样系统整体处理流量比较平稳进行展示;
3.消息队列的缺点?
a:系统可用性降低:
他系统只要运行好好的,那你的系统就是正常的。现在你非要加个消息队列进去,那消息队列挂了,因此,系统可用性降低。
b:系统复杂性提高:
硬生生加个MQ进来,你怎么保证消息没有重复消费?怎么处理消息丢失的情况? 怎么保证消息传递的顺序性?头大头大,问题一大堆,痛苦不已。
c:一致性问题:
A系统处理完了直接返回成功了,人都以为你这个请求就成功了;
但是问题是,要是BCD三个系统那里,BD两个系统写库成功了,结果C系统写库失败了,咋整?你这数据就不一致了。
4.kafka、activemq、rabbitmq、rocketmq都有什么优点和缺点?