说说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

目录
相关文章
|
2天前
|
调度 云计算 芯片
云超算技术跃进,阿里云牵头制定我国首个云超算国家标准
近日,由阿里云联合中国电子技术标准化研究院主导制定的首个云超算国家标准已完成报批,不久后将正式批准发布。标准规定了云超算服务涉及的云计算基础资源、资源管理、运行和调度等方面的技术要求,为云超算服务产品的设计、实现、应用和选型提供指导,为云超算在HPC应用和用户的大范围采用奠定了基础。
|
9天前
|
存储 运维 安全
云上金融量化策略回测方案与最佳实践
2024年11月29日,阿里云在上海举办金融量化策略回测Workshop,汇聚多位行业专家,围绕量化投资的最佳实践、数据隐私安全、量化策略回测方案等议题进行深入探讨。活动特别设计了动手实践环节,帮助参会者亲身体验阿里云产品功能,涵盖EHPC量化回测和Argo Workflows量化回测两大主题,旨在提升量化投研效率与安全性。
云上金融量化策略回测方案与最佳实践
|
11天前
|
人工智能 自然语言处理 前端开发
从0开始打造一款APP:前端+搭建本机服务,定制暖冬卫衣先到先得
通义灵码携手科技博主@玺哥超carry 打造全网第一个完整的、面向普通人的自然语言编程教程。完全使用 AI,再配合简单易懂的方法,只要你会打字,就能真正做出一个完整的应用。
8875 20
|
15天前
|
Cloud Native Apache 流计算
资料合集|Flink Forward Asia 2024 上海站
Apache Flink 年度技术盛会聚焦“回顾过去,展望未来”,涵盖流式湖仓、流批一体、Data+AI 等八大核心议题,近百家厂商参与,深入探讨前沿技术发展。小松鼠为大家整理了 FFA 2024 演讲 PPT ,可在线阅读和下载。
4769 12
资料合集|Flink Forward Asia 2024 上海站
|
15天前
|
自然语言处理 数据可视化 API
Qwen系列模型+GraphRAG/LightRAG/Kotaemon从0开始构建中医方剂大模型知识图谱问答
本文详细记录了作者在短时间内尝试构建中医药知识图谱的过程,涵盖了GraphRAG、LightRAG和Kotaemon三种图RAG架构的对比与应用。通过实际操作,作者不仅展示了如何利用这些工具构建知识图谱,还指出了每种工具的优势和局限性。尽管初步构建的知识图谱在数据处理、实体识别和关系抽取等方面存在不足,但为后续的优化和改进提供了宝贵的经验和方向。此外,文章强调了知识图谱构建不仅仅是技术问题,还需要深入整合领域知识和满足用户需求,体现了跨学科合作的重要性。
|
23天前
|
人工智能 自动驾驶 大数据
预告 | 阿里云邀您参加2024中国生成式AI大会上海站,马上报名
大会以“智能跃进 创造无限”为主题,设置主会场峰会、分会场研讨会及展览区,聚焦大模型、AI Infra等热点议题。阿里云智算集群产品解决方案负责人丛培岩将出席并发表《高性能智算集群设计思考与实践》主题演讲。观众报名现已开放。
|
11天前
|
人工智能 容器
三句话开发一个刮刮乐小游戏!暖ta一整个冬天!
本文介绍了如何利用千问开发一款情侣刮刮乐小游戏,通过三步简单指令实现从单个功能到整体框架,再到多端优化的过程,旨在为生活增添乐趣,促进情感交流。在线体验地址已提供,鼓励读者动手尝试,探索编程与AI结合的无限可能。
三句话开发一个刮刮乐小游戏!暖ta一整个冬天!
|
10天前
|
消息中间件 人工智能 运维
12月更文特别场——寻找用云高手,分享云&AI实践
我们寻找你,用云高手,欢迎分享你的真知灼见!
877 58

热门文章

最新文章