目录

Java-进程-CPU占用率100-问题

目录

Java 进程 CPU占用率100% 问题

1.CPU占用率

现代分时多任务操作系统对 CPU 都是分时间片使用的:比如A进程占用10ms,然后B进程占用30ms,然后空闲60ms,再又是A进程占10ms,B进程占30ms,空闲60ms;如果在一段时间内都是如此,那么这段时间内的占用率为40%;

2.CPU占用率100%原因

线程的运行时间由cpu决定,cpu分给每个线程一个时间片,如果在时间片内,线程一直占有,则是100%;

3.java 进程中CPU占用率100%的常见场景

  • 死循环;
  • 大量Full GC;
  • 耗时太长的计算;
  • 大量线程、上下文切换;

4.排查步骤

4.1.先找到占用CPU的进程;如果是Java进程,继续确定是哪个线程占用了CPU;

1> 查看CPU的进程

top

2> JPS 查看 java 进程

3> 导出java进程的线程栈;PS:文件后缀名通常用tdump;

jstack PID > PID.tdump

4>导出

4.2.根据线程ID从线程栈中找到对应线程栈;分析线程栈内容;