处理问题:java 进程启动后系统cpu使用飙升
jstack可以定位到线程堆栈,根据堆栈信息我们可以定位到具体代码
1、查询java进程,获取进程id
ps -ef | grep java
2、查看该进程内的线程使用情况
top -Hp {pid}
找到cpu使用排名前几的线程
3、打印对应线程的十六进制(jstack 内部显示的是十六进制数据 例如:nid=x54ee)
printf “%x\n” {tid}
4、jstack 打印线程堆栈
jstack {pid} > ./jstack.log
jstack 命令详情:
jstack [option]
jstack [option] executable
jstack [option] [server-id@]remote-hostname-or-ip
option:
-l long listings,会打印出额外的锁信息,在发生死锁时可以用jstack -l pid来观察锁持有情况
-m mixed mode,不仅会输出Java堆栈信息,还会输出C/C++堆栈信息(比如Native方法)
5、打开jstack.log文件 找到对应线程十六进制 nid=x54ee查看具体情况,
如果发现我们的业务代码,则怀疑就是我们的代码死循环或是真的就是cpu密集型的应用了。
如果没发现业务代码,也有可能是第三方包内的bug,导致cpu使用飙高。

本文提供了一套详细的步骤,帮助读者定位并解决Java进程启动后CPU使用率异常升高的问题。通过使用ps、top、printf和jstack等工具,可以有效定位到具体的线程和代码段,进一步分析是否为业务代码死循环或第三方包内bug导致。
4063

被折叠的 条评论
为什么被折叠?



