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

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

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

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

 

  • 注册场景

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

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

 

 

 

  • 问题

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

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

 

  • 优化方向

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

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

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

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

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

  • 最终优化流程

 

 

 

异步处理

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

流量削峰

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

应用解耦

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

原文链接:https://blog.csdn.net/qq_21046665/article/details/108421701

posted @ 2021-03-17 15:57  随★风  阅读(341)  评论(0编辑  收藏  举报