简要步骤如下:
(1)找到最耗CPU的进程;
(2)找到最耗CPU的线程;
(3)查看堆栈,定位线程在干嘛,定位对应代码;
步骤一、找到最耗CPU的进程
工具:top
方法:
- 执行top -c ,显示进程运行信息列表
- 键入P (大写p),进程按照CPU使用率排序

步骤二:找到最耗CPU的线程
工具:top
方法:
- top -Hp 10765 ,显示一个进程的线程运行信息列表
- 键入P (大写p),线程按照CPU使用率排序

步骤三:查看堆栈,定位线程在干嘛,定位对应代码
首先,将线程PID转化为16进制。工具:printf
方法:printf "%x\n" 10804

如上图,10804对应的16进制是0x2a34,当然,这一步可以用计算器。
之所以要转化为16进制,是因为堆栈里,线程id是用16进制表示的。
接着,查看堆栈,找到线程在干嘛。
工具:jstack
方法:jstack 10765 | grep '0x2a34' -C5 --color
- 打印进程堆栈
- 通过线程id,过滤得到线程堆栈
本文提供了一套实用的步骤和工具,帮助读者定位并解决进程和线程级别的高CPU使用率问题。通过top命令筛选最耗CPU的进程与线程,结合jstack工具深入分析线程堆栈,定位代码瓶颈。
147

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



