获取线程状态
-
通过top -c命令可以动态显示进程及其占用资源的排行榜
可以看到,CPU占用率100%的PID是80972,定位到该进程之后,我们再从线程的dump日志中去定位. -
使用top -H -p 80972命令查找到该进程中消耗CPU最多的线程,从下面的打印结果中发现PID=81122的线程CPU占用率最高。
-
通过printf “0x%x\n” 81122命令把对应的线程PID转化为16进制进行打印,之所以要做这步操作是因为线程dump日志中是以16进制来显示线程PID的。
-
执行jstack命令,打印PID=80972进程的线程dump日志,然后通过管道命令grep从线程dump日志中查找到CPU占用率最高的线程。
分析
通过上述操作后,得到的线程dump信息如下,从该信息中我们发现,在WhileThread.run()方法中因为某个操作导致CPU占用率过高,于是基于这个信息我们可以进行分析从而解决该问题。
线程的基本信息:“Thread-3” #30 daemon prio=5 os_prio=0tid=0x00007f84500ce000 nid=0x13ce2 runnable[0x00007f84a78f7000]。
〇 Thread-3表示线程名字,为了更好地辨别,建议大家在使用线程的时候自己进行命名。
〇 #30,线程的编号。
〇 daemon,表示守护线程。
〇 prio,线程的优先级,Java中的线程优先级分为1~10个级别,数字越高表示优先级越高,优先级高的线程能够有更高的概率优先得到CPU的执行。
〇 os_prio,表示操作系统层面的线程优先级,Java中配置的线程优先级最终会映射到操作系统中的线程优先级。
〇 tid=0x00007f84500ce000,JVM内部线程ID。