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;
总结:
感谢每一个认真阅读我文章的人!!!
作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。
软件测试面试文档
我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。