linux java服务故障排查 CPU长期占用率过高的解决方法

linux java服务故障排查之 CPU 长期占用率过高的解决方法

有时候我们可能会遇到CPU一直占用过高的情况 服务一直出现告警的情况
之前我的做法是,直接查找到相关的进程,然后kill了或重启的粗暴方法
这个方法对于一般的应用问题还不大,但是要是是重要的环境的话,可万万使不得 最终还是需要彻底的解决服务吃cpu的情况

如果是重要的环境,那么我们就需要进行更加精确的定位。下面以定位Tomcat应用占用CPU过高的问题为例,讲一下如何解决CPU占用过高问题

1>首选我们要确定top命令中 那个服务占用的cpu最高

top -c
下面展示一些

top -c

linux java服务故障排查 CPU长期占用率过高的解决方法_第1张图片

2>然后我们需要知道这个进程有哪些线程,又是哪个线程在占用大量CPU

(科普一下:线程是进程的单位,一个进程是由若干线程组成的)

top -Hp pid  
#示列: top -Hp 7259
#所以的第一个线程占用CPU过高

linux java服务故障排查 CPU长期占用率过高的解决方法_第2张图片

3>接着要查询这个线程的ID转换为16进制的线程号是多少

printf "%x\n" pid
示列:printf "%x\n" 26481

linux java服务故障排查 CPU长期占用率过高的解决方法_第3张图片
得出16进制的线程号了后,在一次命令进行查询

4>接着我们在用命令查看具体的进程信息

jstack 7259|grep "6671" -A 60
#解释一下jstack是Prints Java thread stack traces for a Java process, core file, or remote debug server
#grep -A 60  则是显示(上下文显示60条)  60条相关的语句,也可以自己改成多条
jstack 8104|grep "1fdb" -A 60

linux java服务故障排查 CPU长期占用率过高的解决方法_第4张图片

你可能感兴趣的:(linux,cpu解决方案,linux,运维,ssh)