系统设计中的消息队列

963b64c514c4deaeead416c16b75a2fd.png
1*QnEHTb57iUU8KPQ-gBzw6w.png

在一个电商平台系统里,每当客户下订单时,你需要:

1.处理支付。2.更新库存。3.发送确认邮件。

在高峰期立即执行所有这些操作,可能会减慢客户的体验。

在这种情况下,我们有大量的应用事件,而无法同时处理所有事件。

95972dfdb110e119c3d196ae4ea96cb4.png
1*5TbadXlJNU3ufSiTK0Wt7Q.png

消息队列的基本架构

消息队列是一个持久化组件,存储在内存中,支持异步通信。它充当缓冲区,并分发异步请求。

消息队列的基本架构很简单。输入服务称为生产者或发布者,创建并将消息发布到消息队列。其他服务称为消费者或订阅者,连接到队列并执行消息定义的操作。

64e2282d31738682ad7ae4a6bfb5fd9d.png
1*MH0AbBSdZi5BgFFhX_5DpQ.png

在实际场景中,可能有许多应用程序写入队列,也有许多服务器从队列读取。

bc30172dc3b7069e2a7461a1684ff6a2.png
1*WeikGShMW69Dwxrn53ooqQ.png

回到例子

在我们的案例中,处理每个任务时,可以将其添加到队列的末尾,然后从这个队列将它们发送到我们的服务器。

1.订单已下: 订单详细信息放入一条消息中。2.消息已发送: 消息被添加到队列中。3.工作程序处理: 独立的进程(工作程序)从队列的前端提取消息并处理任务。

ddbc63916c63c7368c263cfa8d9525ce.png
1*CsMA8OML1pbYE1SHqmDewA.png

我们的服务器确认已接收并处理一条消息,队列则将其移除,以免第二次发送。

09bd6b10dfabd44f17e520c45334ec2a.png
1*cAo5HW6rb1HeLflCtUUFBQ.png

使用消息队列的好处

主要优点是我们解耦了这些事件,消息队列允许我们异步处理这些事件。我们可以将它们排队,直到可以处理。

使用消息队列时,当消费者无法处理消息时,生产者可以将消息发布到队列中。

a4361ab163c4233b78b8f55f6ff91030.png
1*JP9HOn98r9hZAkUWQH34rg.png

消费者即使在生产者不可用时也可以从队列中读取消息。

d86f06d6c42dd73664b23ac312eb999e.png
1*1WWY_M5MdsNdPorpEatXZA.png

另一个很大的好处是它们是持久化的。如果队列崩溃,数据不会丢失,因为它不存储在内存中,而是存储在磁盘上。

8c6166366fb8ed9a2b15096b3dfad3b9.png
1*6jLcDI42TdCpCdWm1EXkGQ.png

如果工作程序在处理消息时崩溃,也没问题!消息仍在队列中,将被另一个工作程序提取。

f7ca0060913c88edf5330a6ae542cf4e.png
1*D1x0P9zMDjVxF_SvE92Cvw.png

消息队列还提供了可扩展性。如果接收到大量订单,队列会变得更长。你可以添加更多的工作程序来处理额外的负载,而不影响网站。

不同的队列类型

消息队列有多种类型。最常见的包括:

FIFO(先进先出): 就像一个普通的队列,消息按照到达的顺序处理。这对于支付处理等情况非常重要。•优先队列: 某些消息可能比其他消息更重要。你可以优先处理这些消息。

31f66053e96f0d845b076588a704c40a.png
1*rEo7STMHIpLSnePwK7JpcQ.png

推送与拉取

一些队列等待工作程序请求消息(拉取式队列),而另一些则主动将消息发送给工作程序(推送式队列)。

03fec61666301cc3887aa6f5cdc86e3a.png
1*o3Dz-ven854KSSZcY0Zh-A.png

示例

以下是一些流行的消息队列示例:

d7b1d76a30015145b1f48bd914a933e7.png
1*LiCdmn63OHwRlPJ_Go_dBg.png

RabbitMQ: 一种多用途队列,适合多种用例。•Kafka: 为高吞吐量和实时数据流设计,适用于日志记录和事件驱动架构。•Amazon SQS(简单队列服务): AWS提供的完全托管的基于云的队列服务。它可扩展且可靠,具有延迟队列和死信队列等功能。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小技术君

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值