为什么要使用消息队列

回答这个问题的思路:

  有个什么业务场景,这个业务场景有个什么技术挑战,如果不用MQ可能会很麻烦,但是你现在用了MQ之后带给了你很多的好处。

 

解耦

 

  使用MQ之前,A系统发送一个数据到BCD三个系统,通过接口调用发送,如果E也要这个数据,或者B又突然不要了,A还得去改代码

  而且A还得考虑其他系统挂了怎么办,超时怎么办

 

 

  使用MQ之后,系统A只负责发消息,对这个消息感兴趣的系统自己去拿到这个消息去消费

  系统A不用考虑自己要给谁去发数据

 

异步

 

  使用MQ之前,A系统接收一个请求,需要在自己本地写库,还需要在BCD三个系统写库,总时长就会变的比较长,给用户的响应就会很慢

 

 

  使用MQ之后,系统A发完消息就可以给用户响应了,一些耗时的操作可以异步处理

 

削峰

 

  比如双11零点的时候,大量用户同时发起请求,如果没有一些高并发处理,网站可能直接就崩溃了

 

 

  使用MQ之后,请求先写入MQ,系统A从MQ中慢慢拉取请求,保证高峰期系统不会挂

  虽然高峰期时,请求会在MQ中积压,但是高峰期过了之后,积压的请求会被慢慢处理掉

 

转自:中华石杉Java工程师面试突击

posted @ 2018-11-21 17:17  __Meng  阅读(483)  评论(0编辑  收藏  举报