1. 背景已经基础知识介绍
消息队列,也就是我们常说的mq(message queue),是在后端开发中非常常用的一个技术。
1.1 消息队列解决了什么问题
主要解决以下几个问题
1.解耦和
很好理解,两个service本来是直接通信的,现在变成了有个中间人,整个的流程是变长了,但是这两个service之间的耦合度肯定是下降了。逻辑图如下:

有MQ时:

2. 异步通信
很多时候,在一个流程里面有的操作是需要立刻执行的,但是有的操作并不需要立刻执行,比如用户注册之后,需要将用户信息写入数据库,同时给用户的邮箱发送一封邮,在这样一个场景里面,对于注册用户来说,将用户信息存入数据库是必须要马上做的事情,而发邮件这件事情却可以在稍后一点再执行也不会有任何影响。消息队列提供了异步处理机制,允许用户把一个消息放入队列,但并不立即处理它。想向队列中放入多少消息就放多少,然后在需要的时候再去处理它们。

3. 峰值处理
在访问量剧增的情况下,应用仍然需要继续发挥作用,但是这样的突发流量并不常见;如果为以能处理这类峰值访问为标准来投入资源随时待命无疑是巨大的浪费。使用消息队列能够使关键组件顶

本文详细介绍了消息队列(MQ)的基本概念、解决的问题、使用MQ的优缺点,以及如何保证其高可用和防止消息重复消费。讨论了Kafka、ActiveMQ、RabbitMQ和RocketMQ的特性,并提出了设计消息队列的架构思路。
最低0.47元/天 解锁文章
979

被折叠的 条评论
为什么被折叠?



