在我们程序开发中,会遇到linux服务器CPU飙高的情况,那这个时候应该如何定位到问题代码呢
1、首先我们需要通过top命令去找到CPU飙高的进程,获取其进程id:pid
2、找到pid之后,继续执行top -p [pid] -H, 通过此命令就能够获取该进程pid下所有的线程信息,找到CPU占据最高的线程pid,为方便区分叫做tid
3、第三步需要将获取到的线程pid进行16进制转换,因为在线程堆栈信息中,线程id是以16进制存在的,执行printf "%x\n" [tid],得到16进制数字,比如a718
4、第四步则是可以进行查看了,使用jstack [pid] |grep a718 -A60,这样则可以查看服务器中,线程占据CPU最高的线程堆栈信息了。