以下代码借鉴了两篇博文
https://blog.youkuaiyun.com/mr__fang/article/details/68496248
http://www.javatang.com/archives/2017/10/19/33151873.html
https://www.cnblogs.com/zhangzihong/p/7402801.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占用过高,在优化时,就可以针对这一部分代码进行优化
本文介绍了一种通过top命令找出CPU占用率高的进程,再利用ps命令找到具体线程ID的方法,并展示了如何使用jstack命令进一步定位到代码的具体行数。
86万+

被折叠的 条评论
为什么被折叠?



