如何查找并解决Windows下Java程序占用CPU高的特定线程问题?
- 内容介绍
- 文章标签
- 相关推荐
本文共计712个文字,预计阅读时间需要3分钟。
我的Java程序偶尔会出现CPU占用很高的状况,一直不知道原因。今天终于抽时间解决了。系统是win2003,使用jvisualvm和jconsole查看,好像只能看到总的CPU占用,看不到每个线程分别占用的CPU。
我的一个java程序偶尔会出现cpu占用很高的情况
一直不知道什么原因
今天终于抽时间解决了
系统是win2003
jvisualvm 和 jconsole貌似都只能看到总共占用的cpu 看不到每个线程分别占用的cpu呢所以在windows平台上要找出到底是哪个线程占用的cpu还不那么容易,linux用top就简单多了
最后的解决方法:
1.找到java进程对应的pid。
找pid的方法是:打开任务管理器,然后点击 "查看" 菜单,然后点击 "选择列",把pid勾上,然后就可以在任务管理器里面看到所有进程的pid值了。(也可以用第三步中提到的工具直接查看)
2.然后把java进程导出快照。直接运行命令。
jstack -l 31372 > c:/31372.stack
我这里是指定把java所有的信息导出到c盘的31372.stack的文件里。
本文共计712个文字,预计阅读时间需要3分钟。
我的Java程序偶尔会出现CPU占用很高的状况,一直不知道原因。今天终于抽时间解决了。系统是win2003,使用jvisualvm和jconsole查看,好像只能看到总的CPU占用,看不到每个线程分别占用的CPU。
我的一个java程序偶尔会出现cpu占用很高的情况
一直不知道什么原因
今天终于抽时间解决了
系统是win2003
jvisualvm 和 jconsole貌似都只能看到总共占用的cpu 看不到每个线程分别占用的cpu呢所以在windows平台上要找出到底是哪个线程占用的cpu还不那么容易,linux用top就简单多了
最后的解决方法:
1.找到java进程对应的pid。
找pid的方法是:打开任务管理器,然后点击 "查看" 菜单,然后点击 "选择列",把pid勾上,然后就可以在任务管理器里面看到所有进程的pid值了。(也可以用第三步中提到的工具直接查看)
2.然后把java进程导出快照。直接运行命令。
jstack -l 31372 > c:/31372.stack
我这里是指定把java所有的信息导出到c盘的31372.stack的文件里。

