文档章节

关于JVM CPU资源占用过高的问题排查

罗文浩
 罗文浩
发布于 2016/04/19 22:00
字数 397
阅读 105
收藏 15



总结下最近工作中问题排查方法,问题是jvm cpu占用过高

一、背景:

    先执行一个java程序里面开了两个线程分别都在while循环做打印操作。    

?
1
# java -cp ./test-threads.jar com.spiro.Main

二、现象:

    通过top命令查看当前CPU情况

    

    可以看到有个java进程占用CPU过高,下面来排查是什么线程的什么代码导致CPU过高。

三、步骤

    先获得PID为2023,上图可以看到,或者通过jps命令获取。 执行以下命令:   

?
1
# top -H -p2023

说明: -H 指显示线程,-p 是指定进程

    结果:


    

    可以看到两个CPU占用较高的线程,记下PID 2033和2034 ( 此处的PID即为线程ID标识) ,将其从十进制转成十六进制表示,可通过windows自带的计算器来转。得到结果分别为7f1和7f2

    再通过jstack命令获取当前线程栈,可暂时保存到一个文件tempfile.txt中;  

?
1
# jstack -l 2023 > tempfile.txt

在tempfile.txt中查找nid=0x7f1的线程:  

    可以看到我们找到的线程Thread-0,以及该线程的状态和正在执行的代码行,本例中显示当前正在执行Worker类的15行。然后可去代码中查看不合理的逻辑

四、总结

    该方法很有用,多次使用该方法定位出程序中的性能问题,在此分享和记录。

本文转载自:http://my.oschina.net/

共有 人打赏支持
罗文浩
粉丝 21
博文 138
码字总数 223451
作品 0
海淀
架构师
私信 提问

暂无文章

刚入职阿里,告诉你真实的职场生活,兼谈P6、P7、P8的等级

一:拿下offer的人,基本上都有什么特征? 二:为什么选择阿里? 三:阿里的工作氛围什么样? 四:阿里的薪资情况? 五:阿里的晋升空间有多大? 最近部门招聘,很多工程师,包括我在内都参与...

java知识分子
14分钟前
1
0

中国龙-扬科
17分钟前
1
0
深入理解定时器系列第一篇——理解setTimeout和setInterval

很长时间以来,定时器一直是javascript动画的核心技术。但是,关于定时器,人们通常只了解如何使用setTimeout()和setInterval(),对它们的内在运行机制并不理解,对于与预想不同的实际运行状...

Jack088
20分钟前
2
0
windows 安装nvm

1、nvw-windows的官网:https://github.com/coreybutler/nvm-windows/releases 2、选择nvm-setup.zip安装 3、配置环境变量 4、检查nvm是否安装成功 使用管理员权限打开一个命令行。输入nvm v...

灰白发
31分钟前
1
0
MySQL

慢日志查询作用 慢日志查询的主要功能就是,记录sql语句中超过设定的时间阈值的查询语句。例如,一条查询sql语句,我们设置的阈值为1s,当这条查询语句的执行时间超过了1s,则将被写入到慢查...

士兵7
32分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部