其他分享
首页 > 其他分享> > 分布式消息队列

分布式消息队列

作者:互联网

背景

某业务需求,大概如下:高并发下提交任务,后端对业务进行处理,且一台设备仅能同时处理一个。于是想到构建一个队列池,翻了翻,大概类似于消息队列,这里做下笔记。

注:摘自一些外链的笔记,侵删。


应用场景

消息队列在实际应用中包括如下四个场景:


1、应用耦合

场景说明:用户下单后,订单系统需要通知库存系统。传统的做法是,订单系统调用库存系统的接口。
在这里插入图片描述
传统模式的缺点:

解耦是消息中间件的一个主要作用,标准的用法是:

生产者生产消息传送到队列,消费者从队列中拿取消息并处理,生产者不用关心是谁来消费,消费者不用关心谁在生产消息,从而达到解耦的目的


2、异步处理

具体场景:用户为了使用某个应用,进行注册,系统需要发送注册邮件并验证短信。对这两个操作的处理方式有两种:串行及并行。

在这里插入图片描述
在这里插入图片描述

应用消息队列:
在这里插入图片描述
按照以上约定,用户的响应时间相当于是注册信息写入数据库的时间,也就是50毫秒。注册邮件,发送短信写入消息队列后,直接返回,因此写入消息队列的速度很快,基本可以忽略,因此用户的响应时间可能是50毫秒。因此架构改变后,系统的吞吐量提高到每秒20 QPS。比串行提高了3倍,比并行提高了两倍


3、限流削峰

具体场景:购物网站开展秒杀活动,一般由于瞬时访问量过大,服务器接收过大,会导致流量暴增,相关系统无法处理请求甚至崩溃。而加入消息队列后,系统可以从消息队列中取数据,相当于消息队列做了一次缓冲。
在这里插入图片描述
比方说一个秒杀需求,一用有1万件商品,如果每笔秒杀订单,都去访问一次数据库,查一查库存,那得花费多长时间啊。

我们可以这样做,用一个消息队列,定制它的长度为1万,1万以内可以存到消息队列,并立马反馈秒杀成功,之后再去做减库存等一系列操作。一万以后不再近消息队列,并立马反馈秒杀失败


4、消息驱动的系统

具体场景:用户新上传了一批照片, 人脸识别系统需要对这个用户的所有照片进行聚类,聚类完成后由对账系统重新生成用户的人脸索引(加快查询)。这三个子系统间由消息队列连接起来,前一个阶段的处理结果放入队列中,后一个阶段从队列中获取消息继续处理。

在这里插入图片描述
该方法有如下优点:


常用消息队列框架介绍

在这里插入图片描述

标签:订单,队列,系统,处理,消息,下单,分布式
来源: https://blog.csdn.net/Touale/article/details/122567504