使用jstack定位线程堆栈信息,精确找到异常代码

以下代码借鉴了两篇博文

https://blog.****.net/mr__fang/article/details/68496248

http://www.javatang.com/archives/2017/10/19/33151873.html


找到CPU利用率持续比较高的进程, 命令:top

使用jstack定位线程堆栈信息,精确找到异常代码

找到CPU使用率较高的线程ID(TID):

命令:ps p 16480 -L -o pcpu,pid,tid,time,tname,cmd

此处为:16498

使用jstack定位线程堆栈信息,精确找到异常代码

将获取的线程号(十进制数)转换成十六进制

printf "%x\n" 16498

结果:4072

结合进程号和线程号,利用jstack查到异常代码所在行

jstack -l <pid> | grep <thread-hex-id> -A 10 命令显示出错的堆栈信息,如下图:

jstack -l 16480| grep 0x4072 -A 10

 -A 10 参数用来指定显示行数,否则只会显示一行信息。

使用jstack定位线程堆栈信息,精确找到异常代码

可以看到在代码的第13行有问题。也就是说是这一句导致cpu占用过高,在优化时,就可以针对这一部分代码进行优化