网站首页 > 技术文章 正文
记得前段时间工作中接到一个任务是优化一个下单接口的性能提高接口的吞吐量TPS,前期通过arthas工具跟踪接口的具体方法调用链路及耗时,发现了影响此接口的性能瓶颈主要是加锁的方式,后来变更了锁的方式后性能大大提升。
程序的大致逻辑是,1.判断余额是否足够>2.保存订单信息>3.扣减钱包余额>4.记录钱包流水;现在我将优化前及优化后的代码分别通过jmeter设置100个线程1s内请求这个接口通过实验观察效果,代码的变更及压测结果大家可以往下看
优化前:采用悲观锁
该方案是将整个事务方法加锁,可以保证下单时接口成功的响应,即使余额不足也会友好的返回余额不足的提示,但是不足的是客户端用户等待的时间较长;此种方案如果是用在商品秒杀销量优先场景下也不是很合适。
>代码
>压测结果(tps 8.4左右)
优化后:采用乐观锁
这种方式不会显示的给整个方法上锁,依赖的是通过sql的条件判断达到数据同步防止超卖情况发生,此种方式实际就是乐观锁的一种实现,经测试程序的吞吐量提升了很多,但是不足的是并发高的情况下扣减余额时仅仅通过数据库返回的更新结果不能准确判断是余额不足发生更新异常。
>压测结果(tps 30左右)
总结
通常影响接口的吞吐量有可能就是锁的粒度的大小,在保证数据同步性的同时我们要根据具体场景具体分析评估后采用合适的锁。
猜你喜欢
- 2025-07-01 固态硬盘协议,分为接口协议和传输协议
- 2025-07-01 这比Postman好用,主要免费,能搞定所有API接口~
- 2025-07-01 对API网关注册和接入的接口安全管理总结
- 2025-07-01 Intel换接口 华硕又搞特殊:似乎没啥用
- 2025-07-01 计算机网络的 166 个核心概念,你知道吗?
- 2025-07-01 原生M.2接口性能怎样?!老平台是否一样生猛?!——事实说话!
- 2025-07-01 计算机网络的 89 个核心概念(计算机网络的核心内容)
- 2025-07-01 高端性价比M.2(PCIe) SSD:SAMSUNG 三星 SM951 NVMe 256GB 开箱简评
- 2025-07-01 java-socket长连接demo体验(java tcp长连接)
- 2025-07-01 AMD常见CPU型号汇总(amd cpu型号大全)
- 1507℃桌面软件开发新体验!用 Blazor Hybrid 打造简洁高效的视频处理工具
- 505℃Dify工具使用全场景:dify-sandbox沙盒的原理(源码篇·第2期)
- 485℃MySQL service启动脚本浅析(r12笔记第59天)
- 465℃服务器异常重启,导致mysql启动失败,问题解决过程记录
- 462℃启用MySQL查询缓存(mysql8.0查询缓存)
- 443℃「赵强老师」MySQL的闪回(赵强iso是哪个大学毕业的)
- 422℃mysql服务怎么启动和关闭?(mysql服务怎么启动和关闭)
- 418℃MySQL server PID file could not be found!失败
- 最近发表
-
- netty系列之:搭建HTTP上传文件服务器
- 让deepseek教我将deepseek接入word
- 前端大文件分片上传断点续传(前端大文件分片上传断点续传怎么操作)
- POST 为什么会发送两次请求?(post+为什么会发送两次请求?怎么回答)
- Jmeter之HTTP请求与响应(jmeter运行http请求没反应)
- WAF-Bypass之SQL注入绕过思路总结
- 用户疯狂点击上传按钮,如何确保只有一个上传任务在执行?
- 二 计算机网络 前端学习 物理层 链路层 网络层 传输层 应用层 HTTP
- HTTP请求的完全过程(http请求的基本过程)
- dart系列之:浏览器中的舞者,用dart发送HTTP请求
- 标签列表
-
- c++中::是什么意思 (83)
- 标签用于 (65)
- 主键只能有一个吗 (66)
- c#console.writeline不显示 (75)
- pythoncase语句 (81)
- es6includes (73)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- chromepost (65)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- js判断是否是json字符串 (67)
- checkout-b (67)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- & (66)
- java (73)
- js数组插入 (83)
- linux删除一个文件夹 (65)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)