延迟和高并发导致的不”幂等“场景及解决方案

本文探讨了在网络延迟和高并发场景下可能导致的不幂等问题,特别是在商品下单和秒拍商品功能中。解决方案包括使用订单流水编号作为唯一键、设置锁机制、一次性token以及利用队列进行资源管理,确保系统的幂等性和数据一致性。
摘要由CSDN通过智能技术生成

网络延迟导致的“不幂等”问题

场景描述:

       一个用户对一个商品进行下单,出于各种原因,在较短时间内,用户多次点击了下单按钮,如果手机端没有预防该情况的发生,那么将会产生多个相同的请求(请求接口相同+请求参数相同),如果服务处理不当将有可能产生多个订单,致使脏数据生成,可能导致应用服务的其它功能异常(风险不可评估)。

场景分析:

        一个合理的下单步骤包括三步骤:商品选择->提交购买(生成唯一订单流水编号)->确认购买

        步骤二:

                生成 一个随机唯一订单流水编号关联 用户信息+商品信息 ,该流水编号作为交易意向标识,用户可以继续交易或者放弃交易,且可用于追溯用户该笔交易的流水

        步骤三:

                用户提交交易意向标识,完成商品交易。

        步骤二是必不可少的,仅有“用户信息+商品信息”不能作为唯一标识来确定用户该次交易操作(商品不应有唯一性)。

解决方案:

        对于同一请求在极短时间内,多个相同请求到达的情况

             

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值