本文主要是介绍jstack定位线程堆栈信息,精确找到异常代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
以下代码借鉴了两篇博文
https://blog.csdn.net/mr__fang/article/details/68496248
http://www.javatang.com/archives/2017/10/19/33151873.html
找到CPU利用率持续比较高的进程, 命令:top
找到CPU使用率较高的线程ID(TID):
命令:ps p 16480 -L -o pcpu,pid,tid,time,tname,cmd
此处为:16498
将获取的线程号(十进制数)转换成十六进制
printf "%x\n" 16498
结果:4072
结合进程号和线程号,利用jstack查到异常代码所在行
jstack -l <pid> | grep <thread-hex-id> -A 10
命令显示出错的堆栈信息,如下图:
jstack -l 16480| grep 0x4072 -A 10
-A 10
参数用来指定显示行数,否则只会显示一行信息。
可以看到在代码的第13行有问题。也就是说是这一句导致cpu占用过高,在优化时,就可以针对这一部分代码进行优化
这篇关于jstack定位线程堆栈信息,精确找到异常代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!