在linux系统下,请按照以下步骤进行检查:
top-c,显示系统运行的进程信息,输入大写p,进程将根据利用率进行排序,可以看到第一列是进程id,如图所示,消耗cpu最多的进程id是5986:
top-hp5986,显示进程的线程运行信息列表,继续输入大写字母p根据cpu利用率对其进行排序,您可以看到第一行,进程5986中消耗cpu最多的线程id是6021:
下一步,让我们看看您的应用程序做了什么。如果是java应用程序,要获得更多与线程相关的信息,可以将上面的进程id转换为十六进制,因为在堆栈中的jav中,存储线程的id是十六进制的。您可以直接命令“printf”%xn“6021”,输出:1785:
接下来,您可以通过线程id(十六进制)查看堆栈信息。有许多工具可以查看堆栈信息。这里我使用jstack命令“jstack5986|grep”0x1785“-c5--输出如下:
通过以上步骤,您可以知道当前系统中占用cpu最多的线程以及该线程在做什么,希望能够解决这个问题。