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

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

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

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

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

支付订单

1、场景描述

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

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的延迟是最低的,对于延迟是越低越好。

此图来源于confluent.io

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/863005.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

每天一个数据分析题(三百九十八)- 逻辑回归

逻辑回归的输出概率在[0,1]的范围内,逻辑回归使用以下哪个函数来实现概率转换? A. Sigmoid B. 求模 C. 平方 D. 几率单位 数据分析认证考试介绍:点击进入 题目来源于CDA模拟题库 点击此处获取答案 数据分析专项练习题库 内容涵盖Pyth…

力扣爆刷第154天之TOP100五连刷36-40(最长公共子序列、二分、二叉树右视图)

力扣爆刷第154天之TOP100五连刷36-40(最长公共子序列、二分、二叉树右视图) 文章目录 力扣爆刷第154天之TOP100五连刷36-40(最长公共子序列、二分、二叉树右视图)一、1143. 最长公共子序列二、94. 二叉树的中序遍历三、82. 删除排…

如何查看端口是否开放

如何查看端口是否开放 大家好,我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿!在网络通信中,端口的开放状态对于应用程序的正常运行至关重要。本文将详细介绍…

Redis 7.x 系列【12】数据类型之基数统计(HyperLogLog)

有道无术,术尚可求,有术无道,止于术。 本系列Redis 版本 7.2.5 源码地址:https://gitee.com/pearl-organization/study-redis-demo 文章目录 1. 概述2. 常用命令2.1 PFADD2.2 PFCOUNT2.3 PFMERGE 3. 应用场景 1. 概述 基数表示数…

static关键字在Java中的作用

static关键字在Java中的作用 大家好,我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿!今天我们将深入探讨Java中的static关键字及其作用。static是Java中一个非常重要的关…

关于 Qt4Qt5迁移至Qt6出现QDesktopWidget和QApplication::desktop()删除后兼容Qt6 的解决方法

若该文为原创文章,转载请注明原文出处 本文章博客地址:https://hpzwl.blog.csdn.net/article/details/140036861 长沙红胖子Qt(长沙创微智科)博文大全:开发技术集合(包含Qt实用技术、树莓派、三维、OpenCV…

【QT】QTableView使用

目录 QTableView是什么QTableView、QStandardItemModel、QStyledItemDelegate区别QTableViewQStandardItemModelQStyledItemDelegate总结 example参考文章 QTableView是什么 QTableView是Qt框架中用于显示和编辑二维表格数据的类。它提供了一个可视化的表格界面,允许…

个人品牌建设:提升职业发展的关键

引言 在当今竞争激烈的职场环境中,拥有强大的个人品牌已经成为职业成功的重要因素。个人品牌不仅可以帮助你在职场中脱颖而出,还能提升你的职业发展机会和个人影响力。本文将详细探讨如何通过系统的方法和策略,构建和提升个人品牌&#xff0…

MySQL存储过程和函数(超详细)

MySQL存储过程和函数 一、什么是存储过程 存储过程就是一些SQL语句的集合,可以简单理解为类似Java中的一个接口函数,函数里面可以使用查询SQL、流程控制语句、定义参数、条件等,用来实现更复杂逻辑的处理。 二、存储过程的作用(…

【期末速成】计算机操作系统 EP04 | 学习笔记

文章目录 一、前言🚀🚀🚀二、正文:☀️☀️☀️2.1 考点七:进程通信2.2 考点八:线程的概念2.3 考点九:处理机调度的概念及原则2.4 考点十:调度方式与调度算法 一、前言🚀…

常见的行为型设计模式

设计模式(三) 常见的行为型模式 1.模板方法模式: 模版模式定义了一个操作的整体流程, 子类可以在不改变算法结构的情况下,重新定义算法中的某些步骤. 假设我们有一个制作饮料的算法框架,这个算法包括以下步骤: 烧水泡制饮料(如…

react+customize-cra使用less+less-loader时,可能遇到的问题及解决办法

目录 1、先附上各依赖版本和config-overrides.js配置代码,按这个版本和配置就没问题 2、问题(注意:问题顺序没有先后之分哦) 2.1、TypeError: Cannot read property tap of undefined 2.2、No module factory available for d…

资金常见业务

资金业务在银行运营中扮演着举足轻重的角色,不仅是重要的资金运用渠道,也是银行资金来源的重要一环。除了通过贷款获取收益外,银行还通过多元化的资金业务实现资金的增值。 资金业务按其性质可以分为多个类别,包括长短期资金业务、…

阐述Python:except的用法和作用?

💝💝💝欢迎莅临我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:「stormsha的主页」…

网络配置(IP、NETMASK、GATEWAY、DNS、DHCP) <持续更新中>

参考: 初学Linux之网络配置(IP、NETMASK、GATEWAY、DNS、DHCP)-CSDN博客【学习笔记】网关 & 路由_网关和路由-CSDN博客【学习笔记】计算机网络 IP地址与MAC地址_根据mac分配ip-CSDN博客【学习笔记】TCP 和 UDP 协议_tcp 发送 syn 应答没有syn ack-CSDN博客 一…

一次进程虚拟内存占用超过200G问题分析

在对智驾软件系统资源进行分析时,发现一个进程虚存占用过高,超过200G top查看内存占用 有一个node应用占用了200G的虚拟内存 pmap查看该进程内存情况 pmap -x -p 8496结果显示有两个异常点,刚好和虚存使用总量吻合 一个50G和一个170G的堆…

Linux: network: 丢包分析的另一个途径 tracing

丢包的另一个思路,内核里有些counter的计数,记录的不准确。这个时候怎么办?就需要使用另外一个方式:/sys/kernel/debug/tracing/event/skb/kfree_skb 的跟踪功能。这个算是对counter的一个补充,可以拿来做统计分析使用…

udp Socket组播 服务器

什么是组播 组播也可以称之为多播这也是 UDP 的特性之一。组播是主机间一对多的通讯模式,是一种允许一个或多个组播源发送同一报文到多个接收者的技术。组播源将一份报文发送到特定的组播地址,组播地址不同于单播地址,它并不属于特定某个主机…

【云原生】最新版Kubernetes集群基于Containerd部署

Kubernetes集群基于Containerd部署 文章目录 Kubernetes集群基于Containerd部署资源列表基础环境一、基础环境准备1.1、关闭Swap分区1.2、添加hosts解析1.3、桥接的IPv4流量传递给iptables的链 二、准备Containerd容器运行时2.1、安装Containerd2.2、配置Containerd2.3、启动Co…

智慧校园-医务管理系统总体概述

智慧校园医务管理系统,作为校园健康管理体系的智能化升级,深度融合信息技术与医疗服务,为师生构筑起一道全方位的健康守护网。医务管理系统以提升校园医疗服务水平、优化健康管理流程为核心目标,通过一系列创新功能,确…