面试官:为什么要使用MQ(消息队列)??

1.为什么要用MQ(消息队列)

在面试中,MQ是面试官常问知识点,那么我们为什么要使用MQ呢?

  1. 异步处理
  2. 流量削峰
  3. 应用解耦

以上是标准问答,那么你是否真的了解MQ该如何使用?以下我会从实际应用场景告诉你MQ应该如何使用。

注册场景

我就直接将我司的真实场景搬过来剖析,这里不拿冷门业务(怕你们看不懂怼我-。-),找一个大部分系统都会有的功能:注册

信息校验->创建账户并入库->创建资金账户->通知其他系统->短信通知

image-20200905162324130

问题

先说一下这种线性的注册方式带来的问题。问题就是因为它是线性的,如果说中间任何一环出现问题,操作失败,都将导致返回失败。

其次就是响应速度慢,而且会随着系统体量的增大越来越慢

优化方向

首先要明确哪一步是不需要立马处理完成的。

创建资金账户:这一步在我们业务操作的时候不存在会有补偿机制,可以延迟处理

通知其他系统:涉及三方系统获取用户信息,实时性要求不是那么高,用户不存在他们会对我们系统询问获取,对接系统越多通知越慢,可以延迟处理

短信通知:这里主要是让消息服务给用户的手机/邮箱发送短信通知,服务本身也有补偿机制,可以延迟处理

以上3个步骤就是可以做延迟处理的步骤,实时性要求并不是很高,并且都对失败的情况有处理,不会影响系统和业务的正常执行。

最终优化流程

image-20200905161809171

异步处理

现在我们可以看到黄色位置由原先的5步变成了现在的两步,响应速度会有极大的提升,这就是异步处理带来的好处。

流量削峰

如果同时注册用户过多,MQ还会起到削峰的作用,因为队列的特性,只有当一条消息处理完成时才会处理下一条消息

应用解耦

蓝色区域的每一项功能都实现了解耦,如短信通知,当任何系统的任何功能,如果想发短信给用户只需要告诉MQ就可以了

2.结语

通过以上案例,我们实实在在的了解了什么是异步处理流量削峰解耦以及为什么要使用MQ和它带给我们的好处。下一篇给大家带来RabbitMQ的原理以及如何在代码中去使用它,让大家在面试和工作中都如鱼得水。

猜你喜欢

转载自blog.csdn.net/qq_21046665/article/details/108421701