博客
关于我
消息队列-优缺点
阅读量:292 次
发布时间:2019-03-03

本文共 875 字,大约阅读时间需要 2 分钟。

优点:

(1)解耦

传统模式的缺点:系统间耦合性太强,如上图所示,系统A在代码中直接调用系统B和系统C的代码,如果将来D系统接入,系统A还需要修改代码,过于麻烦!(若多个应用使用A系统的东西,但是根据业务的需求,可能进行更改,那么就需要频繁的修改代码)

中间件模式:将消息写入消息队列,需要消息的系统自己从消息队列中订阅,从而系统A不需要做任何修改。(A只需要把东西放在消息队列中,谁要用不关乎它的事情)

(2)异步

传统模式缺点:一些非必要的业务逻辑以同步的方式运行,太耗时间。(一个业务涉及了多个操作,有些是非必要的业务。那么若直接同步进行,耗时太长。例如:下单,要付款,去除优惠卷,付款完要计算积分,计算完积分要发短信,那么用户下完单只需要知道是否完成了付款,关于优惠劵与积分等业务逻辑没必要同步进行,耗时。当链路过长就需要用异步来解决)

中间件模式:将消息写入消息队列,非必要的业务逻辑以异步的方式运行,以加快响应速度

(3)削峰

传统模式缺点:并发量大的时候,所有的请求直接怼到数据库,造成数据库连接异常。(秒杀这种活动的时候,所有的请求一起来队缓存或者数据库的时候,当它们承受不了压力的时候,就可能会崩盘。)

中间件模式:系统A慢慢的按照数据库能处理的并发量,从消息队列中慢慢拉取消息。在生产中,这个短暂的高峰期积压是允许的。

缺点

(1)系统可用性降低

​ 系统引入的外部依赖越多,越容易挂掉,当加了消息中间件MQ,那么如果MQ挂了,整套系统关于消费者无法进行消费,会导致系统不可用。

(2)系统复杂性提高

​ 硬生生加个 MQ 进来,你怎么保证消息没有重复消费?怎么处理消息丢失的情况?怎么保证消息传递的顺序性?所以需要对MQ进行维护,导致了系统的复杂性提高了。

(3)一致性问题

​ ABCD是一整个业务,例如A是付钱,B是扣除优惠券,C是增加积分,D是发送成功短信,那么,A 系统处理完了直接返回成功了,人都以为你这个请求就成功了;但是问题是,要是 BCD 三个系统那里,BD 两个系统写库成功了,结果 C 系统写库失败了,这数据就不一致了。

转载地址:http://xanl.baihongyu.com/

你可能感兴趣的文章
Mysql索引合并(index merge)导致的死锁问题
查看>>
MySQL索引和查询优化
查看>>
mysql索引底层数据结构和算法
查看>>
Mysql索引底层结构的分析
查看>>
MySQL索引底层:B+树详解
查看>>
Mysql索引总结
查看>>
mysql索引最左匹配原则理解以及常见的sql使用的索引情况的实测
查看>>
Mysql索引类型
查看>>
MySQL索引背后的数据结构及算法原理
查看>>
mysql索引能重复吗_mysql “索引”能重复吗?“唯一索引”与“索引”区别是什么?...
查看>>
MySQL索引详解(IT枫斗者)
查看>>
MySQL索引那些事:什么是索引?为什么加索引就查得快了?
查看>>
Mysql索引(2):索引结构
查看>>
Mysql索引(3):索引分类
查看>>
Mysql索引(4):索引语法
查看>>
mysql级联删除_Mysql笔记系列,DQL基础复习,Mysql的约束与范式
查看>>
mysql练习语句
查看>>
mysql经常使用命令
查看>>
MySQL经常使用技巧
查看>>
mysql给账号授权相关功能 | 表、视图等
查看>>