MQ:指的是消息队列,队列是一种先进先出的数据结构,消息由生产者发送到mq进行排队,然后由消费者对消息进行处理。典型的场景:qq,微信就是典型的mq场景。
MQ的作用主要有三个方面:
-
异步。异步能够提高系统的响应速度和吞吐量。
-
解耦。服务之间进行解耦,减少服务之间的影响,可以提高系统的稳定性和可扩展性。另外,解耦之后可以实现数据的分发,生产者发送一个消息后,可以由多个消费者进行解耦。
-
削峰。以稳定的系统资源应对突发的流量冲击。
MQ的缺点:
-
系统可用性降低:一旦MQ宕机,整个业务就会产生影响。所以就要考虑MQ的高可用性,在MQ中Kafka的高可用性是最高的。
-
系统复杂度提高:引入MQ之后,数据链路就会变得很复杂,容易导致消息的丢失。所以需要考虑到消息的丢失,首先kafka是会出现少量数据的丢失的,所以不适合消息安全性较高的场景。rocket和rabbitmq的消息都是不容易丢失的,因为这两个都存在事务管理,而kafka并不能进行事务的管理。
-
数据一致性:A系统发消息,B、C两个系统一同处理,如果B系统处理成功,C系统处理失败,这就会造成数据一致性的问题。