1. 背景已经基础知识介绍
消息队列,也就是我们常说的mq(message queue),是在后端开发中非常常用的一个技术。
1.1 消息队列解决了什么问题
主要解决以下几个问题
1.解耦和
很好理解,两个service本来是直接通信的,现在变成了有个中间人,整个的流程是变长了,但是这两个service之间的耦合度肯定是下降了。逻辑图如下:
有MQ时:
2. 异步通信
很多时候,在一个流程里面有的操作是需要立刻执行的,但是有的操作并不需要立刻执行,比如用户注册之后,需要将用户信息写入数据库,同时给用户的邮箱发送一封邮,在这样一个场景里面,对于注册用户来说,将用户信息存入数据库是必须要马上做的事情,而发邮件这件事情却可以在稍后一点再执行也不会有任何影响。消息队列提供了异步处理机制,允许用户把一个消息放入队列,但并不立即处理它。想向队列中放入多少消息就放多少,然后在需要的时候再去处理它们。