java cpu负载过高的查询方法

JVM CPU高排查
本文介绍了一种通过top、jconsole、jps等工具来定位Java应用中CPU使用率高的线程及其具体方法栈的过程。从获取Java进程PID开始,到使用http_load进行压力测试,再到利用jstack导出线程堆栈并分析,提供了一套完整的排查步骤。

 

现象

1.top
a.JPG
2.jconsole:以jconsole -pluginpath $JAVA_HOME/demo/management/JTop/JTop.jar启动
CPU情况:
b.JPG
CPU、堆、线程、内存情况(两次压测):
e.JPG

过程

1.jps -lv找到java进程的pid
2.以http_load -p 8 -s 100 http_load_command.txt命令进行压力测试
3.top -H(或启动后Shift+h),切到以线程方式显示top,找到最上面的线程id号
c.JPG
4.jstack pid > /tmp/a,将堆栈导出
5.将线程id号转成十六进制:echo 'obase=16;要转换的十进制数' | bc  
6.cat /tmp/a | grep -A 20 -B 10 "十六进制数",查看堆栈即可看到当前正在执行的方法栈

工具

  • 查询jvm中cpu使用最高线程的堆栈的流程图
    查询jvm中cpu最高线程堆栈.JPG

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值