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从线程栈中找到对应线程栈;分析线程栈内容;