Jmeter 性能-死锁问题定位+分析

1、环境搭建

①准备脚本,执行压测

②用Jstack 打印日志

复制代码
jstack 112759 >dead.log

③下载日志到本地

复制代码
sz dead.log

2、问题定位

①打开dead.log,搜索deadlock

②查看死锁的线程

③查看死锁位置

3、问题分析

①下载死锁的类文件

复制代码
Sz CaseController.class

②使用jd-gui工具,打开文件,根据提示路径找到死锁的代码

复制代码
at cn.testfan.perf.beihe.pinter.http.CaseController.dead(CaseController.java:81)

4、优化思路

①避免嵌套枷锁

②减少加锁的内容

5、线程阻塞和线程死锁的异同对比

①相同点

都是代码加锁导致

②不同点

阻塞只有一个锁,发生阻塞后只是性能慢,程序可运行;

死锁嵌套枷锁,发生死锁后服务器不相应请求,cpu资源利用率为0;

行动吧,在路上总比一直观望的要好,未来的你肯定会感 谢现在拼搏的自己!如果想学习提升找不到资料,没人答疑解惑时,请及时加入扣群: 320231853,里面有各种软件测试+开发资料和技术可以一起交流学习哦。

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!

相关推荐
程序员三藏1 小时前
Postman持久化保存/设置断言详解
自动化测试·软件测试·python·测试工具·职场和发展·接口测试·postman
夏鹏今天学习了吗3 小时前
【LeetCode热题100(56/100)】组合总和
算法·leetcode·职场和发展
测试19983 小时前
如何写出一个完整的测试用例?
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·接口测试
九章云极AladdinEdu4 小时前
GitHub Actions for AI:构建企业级模型CI/CD流水线
自动化测试·模型部署·mlops·github actions·深度学习调试·ai ci/cd·企业级流水线
向前阿、8 小时前
数据结构从基础到实战——排序
c语言·开发语言·数据结构·程序人生·算法
夏鹏今天学习了吗11 小时前
【LeetCode热题100(57/100)】括号生成
算法·leetcode·职场和发展
郝学胜-神的一滴13 小时前
QAxios研发笔记(二):在Qt环境下基于Promise风格简化Http的Post请求
开发语言·c++·笔记·qt·网络协议·程序人生·http
敲代码的嘎仔13 小时前
数据结构算法学习day3——二分查找
java·开发语言·数据结构·学习·程序人生·算法·职场和发展
小白菜又菜14 小时前
Leetcode 495. Teemo Attacking
算法·leetcode·职场和发展
lllsure14 小时前
【快速入门】JMeter
jmeter