大家好,欢迎来到IT知识分享网。
1.为什么要用MQ?
1)MQ的三个应用场景
1.解耦
2.异步,低延时,提高用户的体验
3.削峰
解耦:场景就是,系统A通过接口,给系统B、C发送数据,如果新来了一个系统D也需要这个数据呢?在系统A中吭哧吭哧写一堆代码,此时如果C系统不需要了这个数据了呢?A系统负责人还要时刻考虑B、C、D系统挂了怎么办?要不要重试?消息要不要重发?A系统负责人头大了。。。。
不使用MQ解耦的图示
使用MQ解耦图示
面试技巧
异步:场景是,A系统接收到一个请求,需要在本地数据库进行数据操作需要100ms,还需要在B、C、D系统中分别进行数据操作200ms、300ms、400ms,最终请求时间是100ms+200ms+300ms+400ms=1000ms,一秒的请求时间,正常互联网要求请求时间为200ms,对比一下,用户感觉系统慢死了。。。。
不使用MQ的同步高延时请求场景
使用MQ异步化之后的接口性能优化
1、为啥 BCD 需要的时长大于 25ms,A 需要的时长却小于 25ms?
对于异步消息,只需要交给 MQ 之后就无需理会,交给其他系统慢慢处理就行。
削峰:场景,假设每天A系统0点到11点,每秒并发请求数量是100个,到了12~1点, 每秒并发请求数量是一万个,系统最大处理并发数是1000个,此时系统就会被打死。。。。。
不使用MQ高峰期被系统被打死
使用MQ进行削峰的场景
2)本人项目业务场景
当时遇到了 XXX 问题,用了 XXX 消息队列,带来了 XXX 好处
2.MQ的优缺点?
系统中引入MQ有这么多好处,那有什么弊端呢?如果没考虑过这个,盲目的去为了使用MQ而使用MQ,给公司和团队挖坑。架构中引入MQ,带来的一些问题
引入MQ带来的一些弊端
3. 不同MQ的区别及适合场景
既然用到了MQ,市面上有好多同类型的MQ,流行的有哪几种啊?每一个MQ的优缺点啊?每一个MQ没有绝对的好坏,就是看哪个场景下可以利用优势,扬长避短
常见的MQ有kafka、rabbitMQ、activeMQ、rockerMQ有什么优缺点啊?
免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/21749.html