秒杀“超卖”问题

news2025/1/23 4:58:19

概述:限时秒杀活动在我们的日常生活中有很多,尤其在“双11”,“618”这类购物节活动中用户的并发数更是海量剧增,那么系统为了防止“超卖”秒杀商品,怎么做才能不影响性能的同时防止超卖。

为了解决“超卖”问题有两种方案:

(1)乐观锁

(2)分布式锁

场景:现有10台IPhone14ProMax,在12:00正式发售;假设现有1000个用户同时抢购

表结构:

一、乐观锁:

模拟环境:存在单个秒杀服务,一个商品服务与一个订单服务;直接想秒杀服务发送请求做秒杀,秒杀服务业务层中调用商品服务的减库存业务方法与新增订单。

思想:基于版本号或时间戳的机制,假设并发操作之间不会产生冲突,只在提交时检查是否有冲突

实现步骤:

1、为shop_product添加一个字段version初始为0充当秒杀乐观锁

2、修改原有的SQL

原下订单修改商品库存的sql:update shop_product set stock=#{stock} where pid=#{pid}

在多用户同时秒杀商品时会出现“超卖”问题,可能两个线程同时读取的库存为1,然后都完成了秒杀操作订购了商品。引入字段version充当乐观锁:每次秒杀商品做库存修改时都会判断与当前version是否为你读的version值,一致说明你操作的过程中别的线程未修改,你就完成秒杀操作version++。  引入version后的sql语句:        

使用Jmeter压力测试工具进行秒杀模拟测试:

postman测试服务间通信成功

二、分布式锁:

模拟环境:存在两个秒杀服务,一个商品服务与一个订单服务;为了简便在订单服务中使用feign的方式向秒杀服务发送请求,秒杀服务业务层中调用商品服务的减库存业务方法与新增订单。

思想:确保在分布式环境下只有一个进程或线程可以访问共享资源

Redis实现分布式锁:利用Redis的setnx命令,这个命令的特征是如果多次执行,只有第一次执行会成功,可以实现互斥的效果。保证获取锁失败后,不再一直获取,尝试一次,成功返回true,失败返回false。

获取锁:
●互斥:确保只有一个线程获取锁
●非阻塞设计,保证获取锁失败后,不再一直获取,尝试一次,成功返回true,失败返回false
○SETNX lock thread1
释放锁:
●手动释放
○DEL key 释放锁,删除即可

实现步骤:

1、引入redis坐标,装配StringRedisTemplate类

2、修改秒杀商品更新库存操作的业务层代码:

命令实现:(1)利用setnx命令存储数据的特点:不存在,返回true;存在,返回false

                           expire命令为key设置有效过期时间,防止服务宕机锁一直不背释放

                  (2)利用set命令添加nx和ex的选项:

                                ● NX:与setnx一致,第一次执行成功
                                ●EX:设置过期时间

                          set key value [EX time秒] [NX]    例如:set lock thread1 EX 10 NX

代码实现:调用setIfAbsent方法等同于set添加nx和ex的选项,保证setnx和expire命令的原子性

在秒杀服务的业务层调用商品服务的减库存与新增订单方法前对分布式锁的获取(setnx)进行判断,获取的线程可以执行秒杀操作,下单成功;同时操作完成后要释放分布式锁(即删除key)

Jmeter压力测试:

初始商品库存信息

用postman测试服务间通信没问题

商品shop_product表

秒杀订单表

总结:

  • 乐观锁用于解决单体秒杀服务的“超卖”问题,能处理高并发,性能高。通过添加version字段,秒杀时会判断当前的version与库中的version是否一致,每次秒杀成功都会对version++的方式实现乐观锁。
  • 分布式锁用于解决多个秒杀服务的“超卖”问题,通过获取分布式锁保证单个秒杀的节点同一时刻只能被一个线程所持有,秒杀操作完成后释放分布式锁。(Redis的setnx命令实现)

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

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

相关文章

mysql或ps提示 vcruntime140_1.dll丢失如何修复,5种方法办法你搞定

今天我在运行一款新安装的软件时,突然遇到了一个让我十分困扰的问题——系统提示vcruntime140_1.dll文件丢失。这个问题导致我无法正常使用这个软件,我也不知道怎么回事,所以我在网上找了一天终于让我找到解决这个问题的方法了,今…

绩效只是绩效

绩效只是绩效 一、背景二、绩效和管理三、绩效和薪资四、QA环节五、总结与反思 一、背景 目前大部分主体的绩效考核方向不明确,有的只是为了考核而考核,那么绩效是什么? 打A(超出预期)和打D(低于预期&…

阿里云ESC服务器CPU一直处于100%该如何排查?

阿里云ESC服务器CPU一直处于100%该如何排查? 问题背景 使用 docker 容器化部署整个项目,然后服务器的CPU一直处于100%,此时就出现了问题:此时如果重新开启一个窗口去连接,或者访问宝塔面板、Navicat连接MySQL就连接不…

使用redis+lua通过原子减解决超卖问题【示例】

文章目录 前言一、准备工作二、不使用Lua三、使用Lua 前言 超卖,即在并发的情况下,所售商品数量大于商品的库存数量。在并发量大的情况下,用户请求同时到达,对数据库进行操作,在没有采取相应的处理的情况时从而导致出…

第八章 Linux实际操作——定时任务调度

第八章 Linux实际操作——定时任务调度 8.1 crond任务调度8.1.1 概述8.1.2 基本语法8.1.3 常用选项8.1.4 快速入门8.1.5 应用实例8.1.6 crond相关指令 8.2 at定时任务8.2.1基本介绍8.2.2 at命令格式8.2.3 at命令选项8.2.4 at时间定义8.2.5 应用实例 8.1 crond任务调度 crontab…

Vulnhub系列靶机---HarryPotter-Nagini-哈利波特系列靶机-2

文章目录 信息收集主机发现端口扫描gobuster目录扫描dirsearch扫描joomscan扫描实现http3访问 漏洞利用Gopherus工具GetShell提权firefox_decrypt工具 总结 靶机文档:HarryPotter: Nagini 下载地址:Download (Mirror) 信息收集 主机发现 端口扫描 访问8…

生成克隆钓鱼网站与对win7进行后渗透操作

目录 目录 前言 系列文章列表 思维导图 1,实验涉及复现环境 2,CS的介绍 2.1,CS的简介 2.2,CS的主要功能 3,CS的安装 3.1,将cobalt_strike_4.5文件夹放到kali中 3.1,放入过程中的注意事项 3.2,如图所示 4,配置工具 4.1,进入c…

Kafka3.0.0版本——消费者(Sticky分区分配策略以及再平衡)

目录 一、Sticky分区分配策略原理二、Sticky分区分配策略 示例需求三、Sticky分区分配策略代码案例3.1、创建带有7个分区的sevenTopic主题3.2、创建三个消费者 组成 消费者组3.3、创建生产者3.4、测试3.5、Sticky分区分配策略代码案例说明 四、Sticky分区分配再平衡案例4.1、停…

机器人抓取检测技术的研究现状

1.分析法 图 1 为分析法在进行抓取检测时所采用的 一般策略[3] [3]Sahbani A, El-Khoury S, Bidaud P. An overview of 3D object grasp synthesis algorithms[J]. Robotics and Autonomous Systems, 2012, 60(3): 326-336. 首先,基于环境限制和机械手与物体模 型进行抓取检…

算法宝典——Java版本(持续更新)

目录 一、链表的算法题(目前9道) 1. 移除链表元素(思路:前后指针) 2. 反转一个单链表 (思路:头插法) 3. 链表的中间结点(思路:快慢指针) 4. 链…

衷心祝福“好教师”节日快乐

在2023年教师节的今天,本“人民体验官”推广人民日报官方微博文化产品《张桂梅说教师这个职业有苦有幸福》。 图:来源“人民体验官”推广平台 人民微博简述道:“今天,张桂梅祝全国老师们节日快乐。” 张桂梅说:“教师…

图像的几何变换(缩放、平移、旋转)

图像的几何变换 学习目标 掌握图像的缩放、平移、旋转等了解数字图像的仿射变换和透射变换 1 图像的缩放 缩放是对图像的大小进行调整,即 使图像放大或缩小 cv2.resize(src,dsize,fx0,fy0,interpolationcv2.INTER_LINEAR) 参数: src :输入图像dsize…

机构企业学员培训知识付费小程序开源版开发

机构企业学员培训知识付费小程序开源版开发 用户注册与登录:提供用户注册和登录功能,以便用户能够访问和使用小程序。个人信息管理:允许用户管理个人资料,包括修改个人信息和上传个人头像。课程浏览:提供课程列表&…

[技术讨论]讨论问题的两个基本原则——17年前的文字仍然有效

前两天又有人找我讨论问题,而且是他自己的项目,内容与我没有任何关系,他说的,却是讨论。 其实就是想来做咨询,又不想付费。 今天看到了十七年前写的这篇文字,就重发一下了,当然有少量文字修订&a…

【Java并发】聊聊ReentrantReadWriteLock锁降级和StampedLock邮戳锁

面试题 1.你说你用过读写锁,锁饥饿问题是什么? 2.有没有比读写锁更快的锁? 3.StampedLock知道吗?(邮戳锁/票据锁) 4.ReentrantReadWriteLock有锁降级机制策略你知道吗? 在并发编程领域,有多线程进行提升整体性能&…

c++ - 抽象类 和 多态当中一些问题

抽象类 纯虚函数 在虚函数的后面写上 0 ,则这个函数为纯虚函数。 class A { public:virtual void func() 0; }; 纯虚函数不需要写函数的定义,他有类似声明一样的结构。 抽象类概念 我们把具有纯虚函数的类,叫做抽象类。 所谓抽象就是&a…

124个Python案例,完整源代码!

大家好,我是涛哥。 很多小伙伴为了掌握爬虫这门技术,投入了大量的时间和精力。他们在深夜里独自码字,他们在周末的时候熟读代码, 但独自学习,没有朋友的陪伴和指导,学习的过程就像是在一条无尽的道路上徘…

【多线程】wait 、notify 和 notifyAll 讲解

wait 、notify 和 notifyAll 讲解 一. wait二. wait 和 sleep 的对比三. notify四. notifyAll五. notify 与 notifyAll 的原理 由于线程之间是抢占式执行的, 因此线程之间执行的先后顺序难以预知. 但是实际开发中有时候我们希望合理的协调多个线程之间的执行先后顺序. 完成这个…

军队状态出现的六种结果,是将帅的过失

军队状态会出现六种坏结果,是将帅的过失 【安志强趣讲《孙子兵法》第35讲】 【原文】 故兵有走者,有弛者,有陷者,有崩者,有乱者,有北者。凡此六者,非天之灾,将之过也。 【趣讲白话】…

【代码分析】初学解惑C++:函数适配器

文章目录 前置知识 运算符的重载“()”一、函数适配器是什么?由遇到的问题引出适配器模式类模式对象模式例1例2例3例4二、实现函数适配器1.定义函数2.定义函数适配器3.使用函数适配器 三、带模板的函数适配器1、自定义unary_function2、改写带…