【浅谈电商】如何防止重复下单

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 首先我们要知道什么时候是下单操作。以JD为例:购物车 -> 结算页面 -> 下单页面- 购物车:购物车- 结算页面:此页面可以查看待支付金额,使用的优惠券,填写地址,运费等等。- 下单页面:此页面可以选择结算方式,并且页面展示付款倒计时,也就是说订单已经创建完成。在下单页面时,由于用户点击下单按钮多次、或者重试策略导致在订单服务中接收到了`两次同样`的下单请求。

【浅谈电商】如何防止重复下单

一、前言

最近正在做电商相关的项目,整理一下解决方案并帮助自己巩固知识点,此方案是结合了目前的业务环境,若有更好的解决的方式很高兴与大家一起讨论。

二、什么是重复下单

首先我们要知道什么时候是下单操作。以JD为例:

购物车 -> 结算页面 -> 下单页面

  • 购物车:购物车
  • 结算页面:此页面可以查看待支付金额,使用的优惠券,填写地址,运费等等。
  • 下单页面:此页面可以选择结算方式,并且页面展示付款倒计时,也就是说订单已经创建完成。

在下单页面时,由于用户点击下单按钮多次、或者重试策略导致在订单服务中接收到了两次同样的下单请求。

image.png

三、如何处理重复下单

重复下单场景,第二次的下单会对数据进行打乱,导致系统整体数据异常

image.png

理想的情景:

image.png

找到了问题的根本原因就可以有针对性的去解决问题。

令牌桶

面对用户的多次点击/提交/刷新页面等操作时,我们可以添加一个防重令牌的操作。每次操作前,给当前用户一个一次性的令牌,点击提交时带着令牌一起,后端会先去校验令牌的有效性,这样来避免恶意刷提交。由于令牌的有效性就好比前朝的尚方宝剑也无法斩本朝的官^_^

上述的操作在一定程度上可以解决重复提交的问题,假如当一个人的速度足够快,也是可以合理去提交一个一模一样的订单,这个时候就需要使用缓存的方式防重。

image.png

Redis

当用户下单时,去Redis中获取一个,即一个标识,同一时间只能有一个人能获取到。获取到之后才可以进行后续的逻辑,例如清除购物车、标记消费券等。若此时另外一个下单请求突破防线进入了系统,首先它需要去Redis获取锁,然而锁已经被占用了,它获取不到直接就返回失败。这里主要保证的是接口幂等性。

image.png

小结

  • 令牌桶:可以防止用户很快的提交请求,主要解决的是防重。
  • Redis:可以使同一时间只有一个下单逻辑在运行(同一用户下),主要解决的是接口幂等性。

ps:锁的含义更像一个标识,有了它你可以为所欲为,没有它什么也做不了。


目录
相关文章
|
12月前
|
存储 关系型数据库 MySQL
mysql数据库备份与恢复
MySQL数据库的备份与恢复是确保数据安全性和业务连续性的关键操作。
531 4
|
SQL 负载均衡 NoSQL
【防止重复下单】分布式系统接口幂等性实现方案
【防止重复下单】分布式系统接口幂等性实现方案
2006 0
【防止重复下单】分布式系统接口幂等性实现方案
|
缓存 Java 开发工具
Spring是如何解决循环依赖的?从底层源码入手,详细解读Spring框架的三级缓存
三级缓存是Spring框架里,一个经典的技术点,它很好地解决了循环依赖的问题,也是很多面试中会被问到的问题,本文从源码入手,详细剖析Spring三级缓存的来龙去脉。
891 24
Spring是如何解决循环依赖的?从底层源码入手,详细解读Spring框架的三级缓存
|
10月前
|
JavaScript 前端开发 开发工具
如何参与开源项目以及贡献代码的流程和注意事项(2024年11月保姆级教程)
本文详细介绍了如何参与开源项目及贡献代码的流程和注意事项,包括选择项目、fork仓库、克隆到本地、阅读贡献指南、提交代码、创建Pull Request等步骤,并强调了沟通礼仪、代码质量的重要性,适合初学者参考学习。
585 0
如何参与开源项目以及贡献代码的流程和注意事项(2024年11月保姆级教程)
|
10月前
|
存储 NoSQL 关系型数据库
Redis的ZSet底层数据结构,ZSet类型全面解析
Redis的ZSet底层数据结构,ZSet类型全面解析;应用场景、底层结构、常用命令;压缩列表ZipList、跳表SkipList;B+树与跳表对比,MySQL为什么使用B+树;ZSet为什么用跳表,而不是B+树、红黑树、二叉树
|
数据采集 JSON 人工智能
Qwen2-Math开源!初步探索数学合成数据生成!
阿里通义团队开源新一代数学模型Qwen2-Math,包含1.5B、7B、72B三个参数的基础模型和指令微调模型。
|
SQL Oracle 关系型数据库
SqlAlchemy 2.0 中文文档(六十七)(1)
SqlAlchemy 2.0 中文文档(六十七)
197 0
|
弹性计算 负载均衡 数据库
2024阿里云服务器试用规则及云产品试用常见问题解答
2024年阿里云服务器可以试用吗?不仅是云服务器产品,包括无影云电脑、云数据库 RDS、统型负载均衡 CLB、对象存储 OSS、文件存储 NAS等云产品都是可以试用的,只是需要注意的是,我们在试用云服务器产品之后,免费试用权益无法与新用户优惠购买活动同享,也就是说,领取了云服务器ECS免费试用权益的用户,将不能参产品新用户的相关活动。本文为大家介绍2024年阿里云服务器和其他云产品的试用规则及试用常见问题解答。
2024阿里云服务器试用规则及云产品试用常见问题解答
|
搜索推荐 算法 Java
深入了解快速排序:原理、性能分析与 Java 实现
快速排序(Quick Sort)是一种经典的、高效的排序算法,被广泛应用于计算机科学和软件开发领域。本文将深入探讨快速排序的工作原理、步骤以及其在不同情况下的性能表现。
900 2
深入了解快速排序:原理、性能分析与 Java 实现
|
消息中间件 Kafka
Kafka消息的重复消费问题如何解决的 ?
Kafka 通过使用消费者组(Consumer Group)来解决消息的重复消费问题。
2062 0

热门文章

最新文章