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;
行动吧,在路上总比一直观望的要好,未来的你肯定会感谢现在拼搏的自己!如果想学习提升找不到资料,没人答疑解惑时,请及时加入群: 786229024,里面有各种测试开发资料和技术可以一起交流哦。
最后: 下方这份完整的软件测试视频教程已经整理上传完成,需要的朋友们可以自行领取【保证100%免费】
软件测试面试文档
我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。