美文网首页
2019-12-21

2019-12-21

作者: 坂本先生的日常 | 来源:发表于2019-12-21 20:43 被阅读0次

本文首发于微信公众号:【坂本先生】

一、为什么使用消息队列

核心的有3个:解耦、异步、削峰

(1)解耦

传统模式:

传统模式的缺点:

系统间耦合性太强,如上图所示,系统A在代码中直接调用系统B和系统C的代码,如果将来D系统接入,系统A还需要修改代码,过于麻烦!

中间件模式:

中间件模式的的优点:

将消息写入消息队列,需要消息的系统自己从消息队列中订阅,从而系统A不需要做任何修改。

(2)异步

传统模式:

传统模式的缺点:

一些非必要的业务逻辑以同步的方式运行,太耗费时间。

中间件模式:

中间件模式的的优点:

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

(3)削峰

传统模式

传统模式的缺点:

并发量大的时候,所有的请求直接怼到数据库,造成数据库连接异常

中间件模式:

中间件模式的的优点:

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

二、消息队列优缺点

系统可用性降低:如果消息队列运行崩溃会直接导致系统故障,可以这么说:“系统的复杂程度和其可用性成负相关”

系统复杂程度增高:需要解决很多问题,例如数据一致性,消息重复消费问题,消息可靠性传输问题

三 、结论

消息队列虽然好,能够帮助我们处理:解耦,异步,削峰问题,但是也会造成系统可用性降低,并提高系统复杂程度。因此我们需要谨慎引入,当然不得不用的时候也得用,最好的方式就是先找一种消息队列自己写一些demo程序来体验一下消息队列,这样今后在遇到响应的业务需求时就能自行判断了

相关文章

  • 2019-12-21遗愿清单

    2019-12-21遗愿清单

  • 2019-12-21我爱你

    2019-12-21我爱你

  • 2019-12-21张思倩分享【每天进步一点点】 爱。

  • 2019-12-21晚间日记

    2019-12-21晚间总结 今天是什么日子 起床:6:00左右 就寝:昨晚12:00左右(可怜(๑ó﹏ò๑)……...

  • 文先森的日常--LP107天

    日精进打卡第468天 姓名:李文杰 (四爷); 公司:中国太平人寿; 日期:2019-12-21 【知~学习】 《...

  • 2019-12-22

    2019-12-21 【日精进打卡第 637 天 【知~学习】 《六项精进》大纲 4 遍共 2404 遍 《大学》...

  • 2019-12-30

    菜菜_d868 字数 223 · 阅读 1 2019-12-21 20:25 姓名:邢彩颜 公司:三亚蔚蓝时代实业...

  • 公益项目管理培训

    2019-12-21 这次培训学习到很多很专业,很系统的公益系统知识,期待能学习到更多的技能和知识

  • 周末作业

    ❤️焦点·智慧父母课堂【肖丹分享第177天·运动第167天·读书第17天~2019-12-21】 又是周末,写作业...

  • 精读  作为意志和表象的世界2019-12-21

    标签 精读 作为意志和表象的世界 2019-12-21 > 01 第56节 419-423 重新概述一下意志表出为...

网友评论

      本文标题:2019-12-21

      本文链接:https://www.haomeiwen.com/subject/xmxnnctx.html