当前位置: 首页 > news >正文

多服务器节点访问解决一人一单问题+redis设置锁方案

项目地址及项目具体介绍-码云仓库:https://gitee.com/flowers-bloom-is-the-sea/distributeNodeSolvePessimisticLockByRedis

测试1:

这里使用jmeter同时启动2各线程:

原来的数据库表的数据:

goods的数据是:

    id   stock  
------  --------1       999

goods_order里没有数据。

在这里插入图片描述

测试结果:

通过打断点调试,goods_order的表里插入了1条数据,goods的库存减一。两个项目工程确实会有一个的isLock为true另一个为false.

这样实际上就完成测试了,但是只能说这个算一个数据量还不够的测试。

测试2:

对于这个超卖的业务进行压力测试:

jmeter开了2个线程组,一组的测试端口为localhost:8081/goods/buyGoodByUserId/1/1另一组为localhost:8082/goods/buyGoodByUserId/1/1,每一组分别1000以上线程来访问,同时启动这2组线程组。

预测结果:对于同一用户,肯定是只能买1份物品,因为锁在redis里获取,一次只有一个线程可以成功,其他线程失败(也就是2000以上线程仅1个线程成功);对于线程组而言肯定仅一个线程组的一个线程操作成功。

测试结果:

这个线程组1000多个线程全部操作失败:

在这里插入图片描述

这个线程组1000多个线程仅1个成功:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-gCQk9oSI-1677037173707)(READMD.assets\image-20230222110917495.png)]

查看了数据库的数据,预测成立,确实库存减一,goods_order数据新增1条。

http://www.lryc.cn/news/16047.html

相关文章:

  • tensorflow 学习笔记(三):神经网络八股
  • 华为OD机试真题Python实现【射击比赛】真题+解题思路+代码(20222023)
  • 【YBT2023寒假Day12 C】树的计数 II(prufer)(结论)(数学)
  • 深入浅出C++ ——多态
  • 华为OD机试真题Python实现【整数编码】真题+解题思路+代码(20222023)
  • FPGA纯Vhdl实现MIPI CSI2RX视频解码输出,OV13850采集,提供工程源码和技术支持
  • 7 个 JavaScript Web API 来构建你不知道的未来网站
  • 跟ChatGPT,聊聊ChatGPT
  • Java 数组(详细教学 基础篇)
  • python装饰器原理 | 常用装饰器使用(@cache, @lru_cache)
  • [oeasy]python0090_极客起源_wozniac_苹果公司_Jobs_Wozniac
  • Spring基础总结(下)
  • 设计模式面试题
  • 需要知道的一些API接口的基础知识
  • 互融云数字资产管理平台综合解决方案
  • 记住这12个要点,你也能打造出让HR和技术主管前一亮的前端简历
  • AQS学习:ReentrantLock源码解析
  • RocketMQ源码分析消息消费机制—-消费端消息负载均衡机制与重新分布
  • 华为OD机试真题Python实现【数据分类】真题+解题思路+代码(20222023)
  • vue项目中引入字体包
  • Linux 文件相关操作
  • 【计算机网络】应用题方法总结
  • Linux 浅谈之性能分析工具 perf
  • 代码随想录-Day7:四数相加、三数之和
  • jsp在线考试系统Myeclipse开发mysql数据库web结构java编程计算机网页项目
  • 【总结】2023数学建模美赛!收官!
  • C# GDI+ winform绘图知识总结
  • 【研究空间复用及函数调用问题】
  • SQL常用查询语句
  • 【Python实战】一大波高颜值主播来袭:快看,某网站颜值排名,为了这个排名我可是大费周章啦,第一名不亏是你...(人脸检测+爬虫实战)