windows下揪出java程序占用cpu很高的线程 并找到问题代码

本文介绍了一种在Windows环境下排查Java应用导致的CPU占用过高的方法。通过使用jstack获取线程堆栈信息,并借助ProcessExplorer定位到具体线程,最终找到问题代码并解决。
 

今天开启个项目后登陆后没过多久后发现,页面慢的很,而且电脑声音响的很,打开任务管理器看了下发现cpu占用高达100%

 

系统是win2010

 

所以在windows平台上要找出到底是哪个线程占用的cpu还不那么容易,linux用top就简单多了

最后的解决方法:

1.找到java进程对应的pid。

找pid的方法是:打开任务管理器,找到详情中的java.exe 找到其pID

 

 

2.然后把java进程导出快照。直接运行命令。

jstack -l 3468> c:/3468.stack

 

我这里是指定把java所有的信息导出到e盘的3468.stack的文件里。
3.在windows下只能查看进程的cpu占用率,要查看线程的cpu占用率要借助其他的工具,我这里用的是微软提供的 Process Explorer v15.3

下载地址http://technet.microsoft.com/en-us/sysinternals/bb896653.aspx

https://pan.baidu.com/s/1hQkdsiv5jJCP6trcqZHc6A  百度提取码 2z5h

下载完后解压运行

 

右键点击需要查看的进程---properties

 

 

 

 

4.然后选择 Threads 选项卡,找到占用cpu的线程的tid,比如我这里是 12464的线程

 

 

 

5.把pid转换成16进制,我这里直接用系统自带的计算器转换,置于为什么要转换,是因为先前用jstack导出的信息里面线程对应的tid是16进制的。

 

最后得到的线程pid的16进制的值为 306b

6.在 e盘的3468.stack文件中查找 306b

 

 然后在代码里面找到server.java

注释掉这段代码后

cpu就会到了正常

原文:https://blog.youkuaiyun.com/hexin373/article/details/8846919

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值