一、为什么使用消息队列
1、实现解耦
耦合指不同模块/系统之间相互作用、相互依赖的关系。RabbitMQ以异步的方式解耦系统间的关系,使用者将业务请求发送到Rabbit服务器,然后就可以返回了,Rabbit会确保请求被正确处理,即使遇到网络异常、Rabbit服务器崩溃等特殊场景。针对这些特殊场景,Rabbit提供了各种机制确保其可用性。
![626720c60f54abb313b54a52917c352b.png](https://i-blog.csdnimg.cn/blog_migrate/e54b7a69d7bc321f39855455830c8f91.jpeg)
2、实现异步
对于大批量的用户操作,同步等待需要很长时间,利用MQ的发布订阅模型,异步处理响应结果可以避免用户不必要的等待。
举一个简单MQ使用场景:使用手机APP实时转账,就采用了MQ低延迟特性,将转账消息投递到MQ中,然后由消费者(对方银行)进行处理,具体到账时间以对方银行收到转账消息,处理完转账操作时间为准。
3、流量消峰
对于像电商网站,每逢店庆、双11等节日会出现瞬间访问量特别大的情况。不能因为系统支持的并发量有限而拒绝部分用户请求,通常做法是承接所有用户请求转变为消息存放到MQ中,由后端业务系统按照顺序进行处理。借助MQ低延迟高吞吐量特性,可以创建多消费者实现负载,从而实现流量消峰。
另外可以利用MQ发布订阅模型可以实现消息广播。