消息队列-mq

本文详细介绍了消息队列(MQ)的基本概念、解决的问题、使用MQ的优缺点,以及如何保证其高可用和防止消息重复消费。讨论了Kafka、ActiveMQ、RabbitMQ和RocketMQ的特性,并提出了设计消息队列的架构思路。
摘要由CSDN通过智能技术生成

1. 背景已经基础知识介绍

消息队列,也就是我们常说的mq(message queue),是在后端开发中非常常用的一个技术。

1.1 消息队列解决了什么问题

主要解决以下几个问题

1.解耦和

很好理解,两个service本来是直接通信的,现在变成了有个中间人,整个的流程是变长了,但是这两个service之间的耦合度肯定是下降了。逻辑图如下:

有MQ时:

2. 异步通信

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

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值