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

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

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

相关推荐
Y1nhl10 小时前
力扣_二叉树的BFS_python版本
python·算法·leetcode·职场和发展·宽度优先
宇钶宇夕11 小时前
S7-200 SMART CPU 密码清除全指南:从已知密码到忘记密码的解决方法
运维·服务器·数据库·程序人生·自动化
Owen_Q11 小时前
Leetcode百题斩-二分搜索
算法·leetcode·职场和发展
程序媛_16 小时前
【JMeter】数据驱动测试
jmeter
汪敏wangmin16 小时前
Fiddler-抓包后直接生成Loadrunner脚本或者Jmeter脚本
前端·jmeter·fiddler
llm20090916 小时前
Jmeter的JDBC数据库连接
数据库·jmeter
程序媛_1 天前
【JMeter】执行SQL
数据库·sql·jmeter
测试老哥1 天前
Python+Selenium实现自动化测试
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
测试老哥1 天前
软件测试之单元测试
自动化测试·软件测试·python·测试工具·职场和发展·单元测试·测试用例
緈福的街口1 天前
【leetcode】584. 寻找用户推荐人
算法·leetcode·职场和发展