一个专业运
维技术分享!

Linux故障排查之CPU占用率过高

有时候我们可能会遇到CPU一直占用过高的情况。之前我的做法是,直接查找到相关的进程,然后杀死或重启即可。这个方法对于一般的应用问题还不大,但是要是是重要的环境的话,可万万使不得。 如果是重要的环境,那么我们就需要进行更加精确的定位。下面以定位Tomcat应用占用CPU过高的问题为例,讲一下如何解决CPU占用过高问题。

一、首先我们需要先top确定一下那个进程占用CPU最高。执行命令top

122_1.png

二、然后我们需要知道这个进程有哪些线程,又是哪个线程在占用大量CPU(科普一下:线程是进程的单位,一个进程是由若干线程组成的)。执行命令top -Hp 8104

可以显示所有的线程 top -Hp pid

122_2.png

这里我只是做简单示例,所以我们就假设第一个线程占用CPU过高

三、接着我们还需要知道这个线程的ID转换为16进制的线程是多少

122_3.png

四、接着我们再使用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条相关的语句

仔细查看这些信息说不定就能发现是什么问题了,因为我这里是正常的,所以看不到什么异常而已

122_4.png

赞(4) 打赏
版权声明:本文采用知识共享 署名4.0国际许可协议 [BY-NC-SA] 进行授权
文章名称:《Linux故障排查之CPU占用率过高》
文章链接:https://www.xlsys.cn/1361.html
本站资源仅供个人学习交流,请于下载后24小时内删除,不允许用于商业用途,否则法律问题自行承担。

评论 抢沙发

评论前必须登录!

 

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏