jstack分析系统cup使用飙升

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值