JVM内存溢出CPU飙升排查方法

一、内存不足

查看linux内存使用情况

free -m

查看java 进程/线程对系统的占用情况 

top 

看堆内存信息

jmap -heap pid

导出dump java堆数据

jmap -dump:live,format=b,file=/dump_.dat pid

打开jvisualVM-》文件-》装入-》堆dump

二、cpu飙升

top命令查看cpu,内存情况

top

 

找到占用cpu高的pid

top -Hp pid

 打印出线程信息

jstack -l pid

假如我们上面 top -Hp 命令找到的占用cpu高的pid是24190

先转成16进制

然后

printf "%x\n" pid

jstack -l javapid | grep '0x+十六进制pid' -A10 --color -A是打印符合条件后n行,-C是环绕n行,-B是之前n行

根据堆栈信息和线程状态,分析cpu占用原因。
如果线程状态是BLOCKED,就是线程阻塞中 

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

今朝花落悲颜色

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值