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

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

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

相关推荐
业精于勤的牙8 小时前
浅谈:算法中的斐波那契数(二)
算法·职场和发展
派大鑫wink9 小时前
【Java 学习日记】开篇:以日记为舟,渡 Java 进阶之海
java·笔记·程序人生·学习方法
LYFlied12 小时前
【每日算法】LeetCode 84. 柱状图中最大的矩形
前端·算法·leetcode·面试·职场和发展
zwjapple12 小时前
全栈开发面试高频算法题
算法·面试·职场和发展
iAkuya13 小时前
(leetcode)力扣100 14合并区间(差分/排序)
算法·leetcode·职场和发展
write199414 小时前
02 jmeter常用组件
jmeter
月明长歌15 小时前
【码道初阶】【LeetCode 102】二叉树层序遍历:如何利用队列实现“一层一层切蛋糕”?
java·数据结构·算法·leetcode·职场和发展·队列
yaoh.wang16 小时前
力扣(LeetCode) 66: 加一 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·跳槽
小南家的青蛙16 小时前
LeetCode第2658题 - 网格图中鱼的最大数目
算法·leetcode·职场和发展
测试人社区-千羽17 小时前
AR/VR应用测试核心要点与实施策略
人工智能·安全·职场和发展·自动驾驶·测试用例·ar·vr