Linux下CPU占用率高分析方法

一、可能有线程一直占用CPU资源

  1. 先通过 ps 查看进程状态,找出进程的PID(8209)。

2.jstack -l 8209 > /usr/local/work/tomcat/8209.stack 导出PID对应的线程信息到文件

3.对导出的线程文件下载本地做分析(可以文本打开)

  1. 通过top -H -p 8209 命令查看对应进程是哪个线程占用CPU过高(eg:8308)

5.printf "%x\n" 8308 转换十进制为十六进制 此处为:2074。

6.在导出的堆栈文件中搜索线程ID等于nid=0x2074的线程,此处即列出了该线程对应的类

7.根据线程信息找到对应的类定位问题成功,可能的原因:

                 1.程序计算比较密集(大型矩阵的运算)

                 2.程序出现了死循环(while循环,hashmap死循环)

                 3. 程序逻辑结构的问题(数据库连接没有释放,连接池死锁,自旋锁一直占用着内存)

二、查看磁盘使用率是不是超出正常范围。(df)

三、查看内存使用率是否超出正常范围(free)

四、jvm内存状态可能出现异常,可能频繁的GC原因。可以适当的改变堆栈比例。

CPU利用率:1 - CPU空闲运行时间/总运行时间

CPU负载(load):是指在一段时间内占用cpu时间的进程和等待cpu时间的进程数(处于被唤醒状态,不是wait状态),取决于CPU队列。

如果现在出现CPU利用率很低,load很高的情况,可能是IO密集型的任务比较多。

你可能感兴趣的:(Linux下CPU占用率高分析方法)