一、背景

    互联网发展的今天,很多问题都会在生产中遇到,假如某天发现系统资源中cpu占用100%,一直居高不下,那么就要进行问题查询了。

二、解决思路

1、查看那个java进程占用最多,top命令

[root@iZ25fdlnov1Z test]# top -H

linux java线程100%的问题定位方法_linux

2、可以明显看到PID为29003的java进程占用cup最高,已占用了95.5%了,可根据进程号进一步查看该进程的线程情况。显示该进程中每个线程的CPU资源消耗情况。

[root@QW121 test]# top -H -p 29003


linux java线程100%的问题定位方法_互联网_02

3、找到占用最高的PID29003后,用jstack打印线程栈信息到stack文件中,如下图:

[root@iZ25fdlnov1Z atm]# jstack -l -F 29003 >29003.stack

linux java线程100%的问题定位方法_java_03

此时,已经将线程栈信息打印进29003.stack文件中了,可以利用cat等命令查看该文件。

4、找到29003的前后20行信息(20行不够可以50行或者更多),并展示出来:

[root@iZ123 test]# cat 29003.stack  |grep -A 20 '29003'

linux java线程100%的问题定位方法_互联网_04


如上图所示,可准确定位到具体哪个类中的那个方法导致的该问题的出现,然后根据代码再一一解决。