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,里面有各种软件测试+开发资料和技术可以一起交流学习哦。

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

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

相关推荐
程序员雷欧3 小时前
大厂OS面试高频题
面试·职场和发展
qq_452396237 小时前
第十四篇:《JMeter插件扩展:自定义函数与第三方插件》
开发语言·python·jmeter
炜宏资料库8 小时前
国网最新:电力市场结算规则解读
职场和发展
洛水水9 小时前
【力扣100题】46.单词拆分
算法·leetcode·职场和发展
qq_452396239 小时前
第十三篇:《分布式压测:JMeter Master-Slave集群》
分布式·jmeter
测试员周周9 小时前
【Appium 系列】第07节-API测试封装 — BaseAPI 的设计与实现
开发语言·人工智能·功能测试·测试工具·appium·自动化·测试用例
洛水水11 小时前
【力扣100题】45.零钱兑换
算法·leetcode·职场和发展
芝士爱知识a12 小时前
2026 年教资面试考前急救软件推荐:基于智蛙面试app的技术评测
面试·职场和发展·智蛙面试·教资面试软件·ai模拟面试·教资考前急救·多模态大模型应用
帅次13 小时前
Android 高级工程师面试参考答案:项目经历、自我介绍与实战案例表达
android·面试·职场和发展
洛水水13 小时前
【力扣100题】47.最长递增子序列
算法·leetcode·职场和发展