有时候我们可能会遇到CPU一直占用过高的情况。之前我的做法是,直接查找到相关的进程,然后杀死或重启即可。这个方法对于一般的应用问题还不大,但是要是是重要的环境的话,可万万使不得。
如果是重要的环境,那么我们就需要进行更加精确的定位。下面以定位Tomcat应用占用CPU过高的问题为例,讲一下如何解决CPU占用过高问题。
一、首先我们需要先top确定一下那个进程占用CPU最高。执行命令top
二、然后我们需要知道这个进程有哪些线程,又是哪个线程在占用大量CPU(科普一下:线程是进程的单位,一个进程是由若干线程组成的)。执行命令top -Hp 8104
这里我只是做简单示例,所以我们就假设第一个线程占用CPU过高
三、接着我们还需要知道这个线程的ID转换为16进制的线程是多少
四、接着我们再使用jstack 8104|grep "1fdb" -A 30查看具体的进程信息。解释一下jstack是Prints Java thread stack traces for a Java process, core file, or remote debug server。至于grep -A 30则是显示(上下文,也就是上下行)下文30条相关的语句
仔细查看这些信息说不定就能发现是什么问题了,因为我这里是正常的,所以看不到什么异常而已
后续遇到实际问题我再进行补充完善