订单系统中的幂等实现

一.订单提交的例子

一个订单生成并支付的过程,大致为:用户点击前端页面提交订单->后端根据此次提交信息生成订单->用户确认订单并进行支付操作->支付成功。

主要分为前端层面,后端系统层面,数据库层面。前端层面不详述,大约是防抖动处理之类的(按钮几秒内禁用)。

1.1 后端系统层面

1.1.1 如何保证生成唯一的订单ID。

为用户界面生成唯一的++token++,并根据此token生成相应的订单ID。

token的获取:

通过令牌桶、队列等等方式。

针对该token对应的数据操作:

分布式锁、事务,保证该token操作的唯一性、原子性,直至生成订单行ID

1.1.2 如何保证订单支付幂等

以订单ID作为唯一标识,贯穿后续操作

订单状态验证、分布式锁、事务保证订单操作的正确性、唯一性、原子性:

其中状态验证主要是保证多线程的处理的时候,订单流转不错乱。

分布式锁保证只有一个线程在处理该带哪个单

事务保证一个线程种,订单相关操作的原子性,一致性。

通过同步接口、轮询机制、重试机制进行支付结果获取:

同步接口若直接返回支付成功,则支付成功。

若未返回,重试(这里要有支付唯一标识)或者轮询结果(查询接口),来获取支付结果,更新订单状态,返回给用户结果(同步接口直接返回,接口超时可以要求用户刷新页面等)。

待补充微服务间的接口、消息幂等,数据一致性等

相关推荐
斯班奇的好朋友阿法法5 小时前
rabbitmq在微服务中配置监听开关
微服务·rabbitmq·ruby
阿里云云原生15 小时前
阿里云微服务引擎 MSE 及 API 网关 2025 年 9 月产品动态
微服务
二宝15218 小时前
黑马商城day3-微服务01
微服务·云原生·架构
roykingw18 小时前
【终极面试集锦】如何设计微服务熔断体系?
java·微服务·面试
我命由我1234518 小时前
Spring Cloud - Spring Cloud 微服务概述 (微服务的产生与特点、微服务的优缺点、微服务设计原则、微服务架构的核心组件)
java·运维·spring·spring cloud·微服务·架构·java-ee
我命由我1234518 小时前
Spring Cloud - Spring Cloud 注册中心与服务提供者(Spring Cloud Eureka 概述、微服务快速入门、微服务应用实例)
java·spring boot·spring·spring cloud·微服务·eureka·java-ee
鼠鼠我捏,要死了捏18 小时前
微服务熔断降级方案对比:Hystrix、Resilience4j与Sentinel实践
微服务·熔断·resilience4j
没有bug.的程序员20 小时前
金融支付分布式架构实战:从理论到生产级实现
java·分布式·微服务·金融·架构·分布式调度系统
没有bug.的程序员1 天前
分布式架构未来趋势:从云原生到智能边缘的演进之路
java·分布式·微服务·云原生·架构·分布式系统
007php0071 天前
百度面试题解析:微服务架构、Dubbo、Redis及其一致性问题(一)
redis·百度·docker·微服务·容器·职场和发展·架构