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


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

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

    1. 异步处理
    2. 流量削峰
    3. 应用解耦
    • 注册场景

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

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

    • 问题

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

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

    • 优化方向

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

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

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

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

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

    • 最终优化流程

    异步处理

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

    流量削峰

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

    应用解耦

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

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

  • 相关阅读:
    装饰器
    返回函数
    用Token令牌维护微服务之间的通信安全的实现
    用Windbg来分析.Net程序的dump
    Windows下docker的安装,将ASP.NET Core程序部署在Linux和Docker中
    StackExchange.Redis学习笔记(五) 发布和订阅
    StackExchange.Redis学习笔记(四) 事务控制和Batch批量操作
    StackExchange.Redis学习笔记(三) 数据库及密码配置 GetServer函数
    StackExchange.Redis学习笔记(二) Redis查询 五种数据类型的应用
    Task及Mvc的异步控制器 使用探索
  • 原文地址:https://www.cnblogs.com/nongzihong/p/14549887.html
Copyright © 2020-2023  润新知