java 程序占满 CPU

664人浏览 / 0人评论

参考

一种CPU占用过高的故障定位分析方法_莫叫石榴姐的博客-CSDN博客

https://blog.csdn.net/qq_33129875/article/details/129283010

https://blog.csdn.net/kx3005320013/article/details/127121812

使用 Arthas

官网:https://arthas.aliyun.com/doc/

其他

方式一

操作:

# 查看进程 pid
top

# ps -ef 或者jps进一步定位得知其具体的后台应用程序名字
ps -ef | grep pid | grep -v grep
jps -l

# 定位具体的线程ID( -m:显示所有的线程;-p:pid进程使用CPU的时间;-o:该参数后是用户自定义格式)
ps -mp pid -o THREAD,tid,time

# 定位具体的应用程序代码位置
# 将需要的线程ID转换成16进制格式
printf "%x\n" pid
jstack pid | grep 十六进制的pid -A60

# 然后定位到 nid=0x十六进制的pid 位置

方式二

操作:

# 查看进程 pid
top

# 进程中的 CPU 占用情况
top -Hp 2619002

# 将需要的线程ID转换成16进制格式
printf "%x\n" pid

# 使用 jstack 获取线程快照并输出到某个文件中
jstack -l 16进制pid> 16进制pid.txt

# 强制输出
jstack -F -l 16进制pid> 16进制pid.txt

参数:

选项 作用
-F 当正常输出的请求不被响应时,强制输出线程堆栈
-m 如果调用到本地方法的话,可以显示C/C++的堆栈
-l 除堆栈外,显示关于锁的附加信息,在发生死锁时可以用jstack -l pid来观察锁持有情况

全部评论