如果服务器资源允许可以考虑一些CPU资源占用工具,例如Perf、SystemTap。
服务器资源不允许的情况下可以使用GDB调试。
步骤如下:
1、使用top查看CPU高占用的程序,记下它的进程ID;
2、多线程服务排查时,需要排查对应线程的情况,为了确定高CPU占用的线程ID 首先,使用top -H -p <进程ID>命令已经可以帮助你识别出哪些线程在消耗最多的CPU资源。记录下这些线程的PID(在top命令中显示为TID,即线程ID)。
3、使用gdb附上正在运行的程序,gdb -p <PID>,替换<PID>
为实际的进程ID。
(3)、gdb进入程序后,一般会默认将程序阻塞住,当可以输入gdb指令时,输入c,让程序继续执行。
3、gdb阻塞进程以后,使用 info threads
命令来列出GDB当前调试的程序中的所有线程。这个命令会显示每个线程的GDB编号(通常是一个从1开始的数字),以及该线程的一些其他信息,比如它正在执行的函数(如果可用)和线程的操作系统ID(如LWP #);
4、使用 thread <GDB线程编号>
命令来切换到指定的线程。例如,如果你想要切换到GDB编号为2的线程,你可以这样做:thread 2;
5、进入到指定线程后,使用bt 可以查看线程调用堆栈信息,可以看到该线程是具体处理什么业务,从而定位代码中占用CPU最高的地方。
如图: