[心缘地方]同学录
首页 | 功能说明 | 站长通知 | 最近更新 | 编码查看转换 | 代码下载 | 常见问题及讨论 | 《深入解析ASP核心技术》 | 王小鸭自动发工资条VBA版
登录系统:用户名: 密码: 如果要讨论问题,请先注册。

[备忘]JVM的cpu100%排查命令

上一篇:[备忘]nginx转发upstream时,一直attempt was made to access a socket in a way forbidden by its access perm
下一篇:[备忘]nginx静态资源之root和alias,不要用中文路径

添加日期:2021/3/28 2:34:15 快速返回   返回列表 阅读865次
top
查看高cpu进程pid=1234

top -H -p 1234
查找进程内cpu占用较高的线程pid

printf “%x\n” 1234
并转成十六进制ea88

jstack 1234
查看线程栈信息,并找到ea88对应的线程,发现其是VM Thread,判断是jvm gc线程


jstat -gcutil 1234 1s 10
查看gc情况,发现几乎每秒一次full gc


jmap -heap 1234
查看jvm的堆栈使用情况,发现新生代和老年代空间充足


jstat -gc 1234 1s 3
查看gc的各分区内存占用情况,发现matespace使用100%


查看gc日志
提前配置jvm gc日志输出 -XX:+PrintGCDetails -XX:+PrintGC;确定是由于matespace空间不足导致频繁full gc


分析堆栈信息
jmap -histo 1234


查看实例信息
jmap -dump:live,format=b,file=heap.bin 1234
导出堆内存信息,可使用mat分析
 

评论 COMMENTS
没有评论 No Comments.

添加评论 Add new comment.
昵称 Name:
评论内容 Comment:
验证码(不区分大小写)
Validation Code:
(not case sensitive)
看不清?点这里换一张!(Change it here!)
 
评论由管理员查看后才能显示。the comment will be showed after it is checked by admin.
CopyRight © 心缘地方 2005-2999. All Rights Reserved