标签:str 依赖 库存 技术 处理 邮件服务 拉取 订单 无法
以用户注册为例,一般情况下:
分下一下,上面过程存在的一些问题:
采用mq的方式实现:
过程:
将依赖于3个服务转换为只依赖于mq服务,只需要保证注册服务、mq服务高可用,即可以保证注册服务的高可用,相比保证其他3个服务高可用上容易了许多。
以电商中的秒杀场景为例,采用同步处理:
分析一下,存在的问题:
秒杀场景,商品数量有限,请求量非常大,每个请求来了都做以上处理,直接会把数据库压垮,导致数据库无法对外提供服务,数据库的不可用直接导致整个业务的不可用,秒杀活动打水漂。
秒杀中数量一般是有限,大量用户抢购,其实最终只有很少的用户能够抢购到
大家都有在银行办理业务的经验,银行处理业务的流程:领号、排队、等待叫号办理业务。
秒杀中我们也可以参考银行办理业务的流程:
从上面可以看出,从接受用户请求到响应用户请求,未访问数据库,只有生成编号和发送消息的操作,这部分处理速度是非常快的,不存在性能的问题,数据库也不存在压力的问题了,所有用户的请求都被作为一条消息投递到mq进行异步处理;从而解决了秒杀中同步处理遇到的各种问题。
其他一些使用场景
mq系列整个内容,我们将讨论:
标签:str 依赖 库存 技术 处理 邮件服务 拉取 订单 无法
原文地址:https://www.cnblogs.com/liliuguang/p/11539961.html