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

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

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

相关推荐
~plus~4 小时前
Harmony核心:动态方法修补与.NET游戏Mod开发
开发语言·jvm·经验分享·后端·程序人生·c#
~plus~5 小时前
WPF八大法则:告别模态窗口卡顿
开发语言·经验分享·后端·程序人生·c#
太阳之神aboluo5 小时前
压测软件-Jmeter
java·运维·jmeter
三千花灯5 小时前
jmeter之导出接口
jmeter
文人sec5 小时前
性能测试-jmeter实战2
jmeter
会又不会5 小时前
JMeter-SSE响应数据自动化2.0
jmeter·自动化
程序媛_5 小时前
【JMeter】后置处理器 - 提取器
jmeter
程序员三藏5 小时前
如何使用Jmeter进行压力测试?
自动化测试·软件测试·python·测试工具·jmeter·测试用例·压力测试
空中湖6 小时前
免费批量图片格式转换工具
图像处理·python·程序人生