处理问题: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使用飙高。