说说MQ在你项目中的应用(二)商品支付

简介: 本文总结了消息队列(MQ)在支付订单业务中的应用,重点分析了RabbitMQ的优势。通过异步处理、系统解耦和流量削峰等功能,RabbitMQ确保了支付流程的高效与稳定。具体场景包括用户下单、支付请求、商品生产和物流配送等环节。相比Kafka,RabbitMQ在低吞吐量、高实时性需求下表现更优,提供了更低延迟和更高的可靠性。

看了不少关于MQ的文章,也对MQ的作用做了一些总结。通常来说MQ有三大功能:异步处理、系统解耦和流量削峰。但我觉得这些功能本质上都是围绕着异步这个核心来的,只是针对不同的业务场景做了些调整。

现在市面上常用的MQ中间件,如RabbitMQ、RocketMQ和Kafka,都是大家耳熟能详的。最近,Apache基金会推出的Pulsar也挺火的,口碑不错,只还差一些大项目实战来检验它。

如今,MQ在现在的项目里基本是标配了。这篇文章主要是梳理一下自己所在项目中是怎么用MQ的,复盘一下使用MQ的场景。

这里接上篇,此篇主要梳理的是支付订单的业务场景。

支付订单

1、场景描述

添加图片注释,不超过 140 字(可选)

业务流程比较长, 和一般的订单业务有点不太一样的地方就是商品是由第三方系统制作的。

2、实现分解

业务分解

  1. 用户选择自己需要的商品及年限
  2. 系统根据用户选择,自动计算出价格及相关的信息展示给用户
  3. 用户确认后,提交订单,订单服务收到订单后存储在DB同时,给Rabbitmq发送支付任务。如果DB保存成功,MQ失败则重试,重试失败则转人工。
  4. 支付中心监听到支付消息,向第三方支付平台发起支付请求,第三方支付平台返回支付二维码
  5. 如果支付未完成或支付失败或不小心关闭支付页面,用户重新进入后可以重新扫码支付
  6. 用户扫码支付成功后,第三方支付平台异步通知支付结果,一般通知失败有多次重新通知的机制。比如支付宝:

在进行异步通知交互时,如果支付宝收到的应答不是 success,支付宝会认为通知失败,会通过一定的策略定期重新发起通知。重试逻辑为:当未收到success立即尝试重发 3 次通知,若 3 次仍不成功,则后续通知的间隔频率为:4m、10m、10m、1h、2h、6h、15h

当然有可能回调服务异常,调用方也可以去支付平台反查支付结果。

  1. 支付中心支付完成后,会向rabbitmq发送完成消息
  2. 商品服务收到消息后会向第三方发起调用商品生产的服务,生产完成后向rabbitmq发送商品制作完成消息
  3. 物流服务收到消息后调用第三方物流接口发起快递(之前下单用户已经填写物流信息),物流完成后,MQ通知订单服务。
  4. 订单服务收到后更新订单状态,完成订单。

优势分析

在此业务场景中,使用消息队列(RabbitMQ)具有以下优势和必要性:

  1. 解耦:RabbitMQ允许系统间的松耦合,例如,如果订单系统需要通知支付和物流服务,通过MQ,订单系统只需将消息发送到队列,而不必直接与其他系统通信。这样,即使业务流程发生变化,也不需要修改订单系统的代码。
  2. 异步处理:RabbitMQ支持异步通信,允许系统在处理长时间运行的任务时不阻塞用户请求。例如,用户下单后,订单系统可以立即响应,而支付和流程操作可以在后台异步进行。
  3. 削峰填谷:在高流量时段,RabbitMQ可以作为缓冲,接收突发的大量请求,然后慢慢地处理这些请求,避免直接压力过大导致系统崩溃。
  4. 可靠性和持久化:RabbitMQ可以保证消息的可靠传递,即使处理系统暂时不可用,消息也可以存储在队列中,待系统恢复后再进行处理。 MQ应答、持久化等机制可以保证整个业务的最终一致性。

3、小结

此业务场景选择RabbitMQ而非继续沿用之前搭建的Kafka,主要是基于对系统需求的深入分析。Kafka作为一款高性能的消息队列系统,其设计初衷是为了处理大规模数据流的高吞吐量场景。尽管Kafka同样具备低延迟和确保消息不丢失的特性,但在当前项目中,我们面临的是消息量相对较小,却对消息处理的实时性有较高要求的场景。

RabbitMQ,以其卓越的灵活性和低延迟特性,在此类场景下表现得更为出色。它能够提供毫秒级的消息传递延迟,并且通过其丰富的路由策略和消息确认机制,确保了消息传递的可靠性和准确性。因此,在综合考虑了系统的实际需求和两款消息队列产品的特性后,我们最终决定采用RabbitMQ来满足项目对低延迟和高可靠性的双重需求。

在下图可以看到低吞吐量的情况下,rabbitmq的延迟是最低的,对于延迟是越低越好。


添加图片注释,不超过 140 字(可选)


此图来源于confluent.io

相关实践学习
快速体验阿里云云消息队列RocketMQ版
本实验将带您快速体验使用云消息队列RocketMQ版Serverless系列实例进行获取接入点、创建Topic、创建订阅组、收发消息、查看消息轨迹和仪表盘。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
目录
相关文章
|
2月前
|
物联网 Linux 开发者
快速部署自己私有MQTT-Broker-下载安装到运行不到一分钟,快速简单且易于集成到自己项目中
本文给物联网开发的朋友推荐的是GMQT,让物联网开发者快速拥有合适自己的MQTT-Broker,本文从下载程序到安装部署手把手教大家安装用上私有化MQTT服务器。
820 5
|
3月前
|
消息中间件 存储 Kafka
一文带你从入门到实战全面掌握RocketMQ核心概念、架构部署、实践应用和高级特性
本文详细介绍了分布式消息中间件RocketMQ的核心概念、部署方式及使用方法。RocketMQ由阿里研发并开源,具有高性能、高可靠性和分布式特性,广泛应用于金融、互联网等领域。文章从环境搭建到消息类型的实战(普通消息、延迟消息、顺序消息和事务消息)进行了全面解析,并对比了三种消费者类型(PushConsumer、SimpleConsumer和PullConsumer)的特点与适用场景。最后总结了使用RocketMQ时的关键注意事项,如Topic和Tag的设计、监控告警的重要性以及性能与可靠性的平衡。通过学习本文,读者可掌握RocketMQ的使用精髓并灵活应用于实际项目中。
2102 8
 一文带你从入门到实战全面掌握RocketMQ核心概念、架构部署、实践应用和高级特性
|
6月前
|
消息中间件 人工智能 自然语言处理
基于 RocketMQ 事件驱动架构的 AI 应用实践
基于 RocketMQ 事件驱动架构的 AI 应用实践
188 2
|
6月前
|
消息中间件 存储 前端开发
MQ有什么应用场景
MQ有什么应用场景
|
9月前
|
消息中间件 存储 监控
说说MQ在你项目中的应用(一)
本文总结了消息队列(MQ)在项目中的应用,主要围绕异步处理、系统解耦和流量削峰三大功能展开。通过分析短信通知和业务日志两个典型场景,介绍了MQ的实现方式及其优势。短信通知中,MQ用于异步发送短信并处理状态更新;业务日志中,Kafka作为高吞吐量的消息系统,负责收集和传输系统及用户行为日志,确保数据的可靠性和高效处理。MQ不仅提高了系统的灵活性和响应速度,还提供了重试机制和状态追踪等功能,保障了业务的稳定运行。
280 7
|
10月前
|
消息中间件 存储 Apache
探索 RocketMQ:企业级消息中间件的选择与应用
RocketMQ 是一个高性能、高可靠、可扩展的分布式消息中间件,它是由阿里巴巴开发并贡献给 Apache 软件基金会的一个开源项目。RocketMQ 主要用于处理大规模、高吞吐量、低延迟的消息传递,它是一个轻量级的、功能强大的消息队列系统,广泛应用于金融、电商、日志系统、数据分析等领域。
980 0
探索 RocketMQ:企业级消息中间件的选择与应用
|
消息中间件 存储 传感器
RabbitMQ 在物联网 (IoT) 项目中的应用案例
【8月更文第28天】随着物联网技术的发展,越来越多的设备被连接到互联网上以收集和传输数据。这些设备可以是传感器、执行器或其他类型的硬件。为了有效地管理这些设备并处理它们产生的大量数据,需要一个可靠的消息传递系统。RabbitMQ 是一个流行的开源消息中间件,它提供了一种灵活的方式来处理和转发消息,非常适合用于物联网环境。
649 1
|
消息中间件 开发工具
【Azure Event Hub】原生应用中使用RabbitMQ,是否可以不改动代码的情况下直接转换为使用Event Hub呢?
【Azure Event Hub】原生应用中使用RabbitMQ,是否可以不改动代码的情况下直接转换为使用Event Hub呢?
|
2月前
|
消息中间件 数据管理 Serverless
阿里云消息队列 Apache RocketMQ 创新论文入选顶会 ACM FSE 2025
阿里云消息团队基于 Apache RocketMQ 构建 Serverless 消息系统,适配多种主流消息协议(如 RabbitMQ、MQTT 和 Kafka),成功解决了传统中间件在可伸缩性、成本及元数据管理等方面的难题,并据此实现 ApsaraMQ 全系列产品 Serverless 化,助力企业提效降本。
|
11月前
|
消息中间件 JSON Java
开发者如何使用轻量消息队列MNS
【10月更文挑战第19天】开发者如何使用轻量消息队列MNS
761 104