CPU使用率高问题排查(jstack)
1.编写代码
public class Demo {
public static void main(String[] args) {
System.err.println("测试开始");
while(true){
}
}
}
编写一个死循环代码。
执行此代码
#编译
javac Demo.java
#执行
java Demo
注意:可能上面两条十分简单的
java
命令,就难倒了一大批人,毕竟咱们都用惯了idea
等开发工具,已经忘记了基本的命令了。
- 编译
- 执行
好家伙,都执行报错了Error: Could not find or load main class Demo
然后一顿百度,大部分都说要注意package
包名的问题,可是哥们这,都没有package
的。
最后找到一篇文章是说,要注意classpath
的问题,我这确实是这个问题导致的。
- 处理的办法有两个:
1.将classpath配置在环境变量中。
2.执行java的命令时,带上classpath参数
那这里,咱们使用第2种方式:
java -cp /root/Demo Demo
测试正常!!!^_^
注意:-cp是,-classpath的缩写
2.找到CPU占用率高的进程
我们可以观察到top查看cpu占用高的进程。
找到cpu占用率为 100%的线程。
PID 为
7744
3. 导出执行堆栈
jstack 7744 >> java.txt
`7744` 为进程号
jstack
命令是JDK
工具之一,使用该命令可以打印正在运行中Java
进程的栈信息。
4. 查占用率高的线程
top -H -p 7744
找到线程号 为
7745
5. 转换16进制
printf "%x\n" 7745
执行后 为 1e41
6. 在之前导出的堆栈文件查找
查找1e41
"main" #1 prio=5 os_prio=0 tid=0x00007fd79c009000 nid=0x1e41 runnable [0x00007fd7a205d000]
java.lang.Thread.State: RUNNABLE
at Demo.main(Demo.java:11)
发现是我们的Demo第11行出了问题,这样找回源码,去掉死循环即可。
好了,以上就是用jstack对CPU使用率高问题的排查了!!!
今天就先到这里了,溜了溜了溜了!!!^_^
觉得有收获的,帮忙点个赞
呗!!!
转载自:https://juejin.cn/post/7096007844972986375