原文路径:https://blog.csdn.net/ningzuobei/article/details/48828915

最近在测试一个用java语言实现的数据采集接口时发现,接口一旦运行起来,CPU利用率瞬间飙升到85%-95%,一旦停止就恢复到40%以下,这让我不得不面对以前从未关注过的程序性能问题。

在硬着头皮查找资料定位错误修正bug的过程中参考了下面两篇文章:

windows下揪出java程序占用cpu很高的线程 并找到问题代码 死循环线程代码:http://blog.csdn.net/hexin373/article/details/8846919

java程序cpu占用过高问题分析:http://www.tuicool.com/articles/ZRzmAvZ(这篇文章中的图片显示不了)

最初想通过java自带的jconsole和jvisualvm来调试,但发现jconsole只能知道应用整体情况,不能定位问题,而jvisualvm最多查找到类,

如果所示,但不能更详细的进行定位。于是参考了上面两篇文章一步步实现了最终目的。

一、查找进程

查找问题进程比较简单,因为问题集中在CPU资源占用过高,那么我们查找进程时只需关注CPU。方法有两种:

1、查看Windows任务管理器

打开Windows任务管理器,查看——>选择列,勾选PID,然后查看进程项,并让其按照CPU列排序如图,找到 javaw.exe进程,其PID是9272。

2、利用jvisualvm工具

打开工具,然后启动应用,在Applications面板中即可看到应用所在进程的PID9272。

需要注意的是该工具并不能定位到线程。

查找到进程以后,将该进程的信息保存到本地,在cmd命令窗口中执行命令:jstack 9272 > C:\test\cdf.log,该命令的作用是将PID为9272的进程信息保存在本地C:\test\cdf.log文件中。

二、查找线程

根据进程查找线程,也有两种方法。

1、使用window自带命令pslist

首先确认系统是否安装了pslist命令程序,如果命令不识别即没有安装,则上微软官方网址http://technet.microsoft.com/en-us/sysinternals/bb896682.aspx下载,下载完将其解压到C:\Windows\System32路径下即可使用。

在cmd命令窗口中执行命令:pslist -dmx 9272,该命令的作用是罗列属于9272进程的线程信息。

通过该命令可以看到TID为9368和12484的线程占用资源最多。这样就基本确定了线程。

2、利用微软提供的Process Explorer工具

一般在windows下只能查看进程的CPU占用率,想要查看线程的CPU占用率可以通过该工具。下载地址是:http://technet.microsoft.com/en-us/sysinternals/bb896653.aspx

下载后运行起来,找到PID为9272的进程

右键点击Properties...选项,看到如下信息:

可以看到占用CPU最多的也是TID为9368和12484的两个线程。

三、问题定位

问题定位需要以下步骤:

1、将线程TID转换为十六进制

因为通过jstack工具导出的信息中线程TID是十六进制的,所以我们首先转换进制,这里通过系统自带的计算器进行转换。

   

记录下2498这个数字。

2、在jstack工具导出的cdf.log中查找“2498”

通过Notepad++工具打开该文档,搜索到如下信息,可以看到问题定位到了MQStart.java:174。

去程序中需找该代码:

同理,对于TID=12484的线程也如同以上步骤进行查找,找到了170行代码。

由此基本可判断问题就出在了该段代码上。

四、修复bug

1、查找原因

通过以上步骤已经定位到了代码片段,但是这段代码看上去没什么错误,查找资料说很多情况是进入死循环了,但是这里确定不会死循环。思路似乎进入了死胡同。

无奈之下我将170行的if内的代码段全注释掉了,发现CPU依然飙高,这说明并不是这几行代码的错误,然后我if内做了一个输出操作,发现程序快速的不间断的进行输出。

        ====》

看到这个结果我突然醒悟,这段代码虽然没有进入死循环,但是循环内的代码并不复杂,而且没必要如此频繁的进行检查操作,这中间应该停歇一下。

2、修改方法

根据以上分析,我修改了这段代码:

再次运行测试发现CPU维持在50%以内。

Windows服务器java.exe占用CPU过高问题分析及解决相关推荐

  1. Windows之——SECOH-QAD.exe占用CPU太高解决方法

    某些的僵尸文件.整个删除注册表 HKEY_LOCAL_MACHINE\SOFTWARE\MICROSOFT\WINDOWS NT\CURRENTVERSION\IMAGE FILE EXECUTION ...

  2. 41、java应用占用cpu过高原因分析

    线上服务器cpu占用过高问题排查 1.定位最耗cpu的进程 命令:top 2.定位最耗cpu的线程 命令:Top –Hp PID 例如:Top –Hp 12086 3.打印线程堆栈信息 命令:Prin ...

  3. Java程序占用 CPU 过高怎么排查

    Java程序占用 CPU 过高怎么排查 线上一台服务器 CPU 使用率100% 了,如果你碰到这样的情况,如何排查并找到问题原因? 这就是一个套路题,所谓套路题就是有标准的套路解法的,掌握了套路,不仅 ...

  4. 解决Win10桌面Explorer.exe占用CPU过高的问题。

    explorer.exe 桌面 Start Address ntdll.dll!RtlInitializeResource+0x410 shcore.dll!Ordinal172+0x30 Frame ...

  5. win7启动后trustedinstaller.exe占用cpu过高问题

    本文参考 http://www.drivers.com/update/pc-health/how-to-resolve-trustedinstaller-exe-high-cpu-usage/ 笔者笔 ...

  6. linux下查找java进程占用CPU过高原因

    linux下查找java进程占用CPU过高原因 1. 查找进程 top查看进程占用资源情况 明显看出java的两个进程22714,12406占用过高cpu. 2.查找线程 使用top -H -p &l ...

  7. 打开Vscode提示rg.exe占用cpu过高,电脑卡顿

    Vscode更新之后rg.exe占用cpu过高 文件->首选项->搜索"search.followSymlinks"改为false 图片:

  8. java.exe占用cpu高_Java进程cpu占用过高问题解决

    cpu是时分(time division)的,操作系统里有很多线程,每个线程的运行时间由cpu决定,cpu会分给每个线程一个时间片,时间片是一个很短的时间长度,如果在时间片内,线程一直占有,则是100 ...

  9. 趣味编程故事|java进程占用cpu过高怎么办,别急我来帮你

    关注公众号"AI码师"领取2021最新面试资料一份 [主演] 运维小哥:小李 测试小姐姐:小红 开发人员:本色出演 [剧情] 在一个阳光明媚的清晨,原本还在睡梦中的我,被小李(运维 ...

最新文章

  1. ZeroMq实现跨线程通信
  2. 重置SQLSERVER表的自增列,让自增列重新计数
  3. u32转换bool类型_4.29.类型转换
  4. 机器学习顶刊文献_人工智能顶刊TPAMI2019最新《多模态机器学习综述》
  5. Windows平台真实时毫秒级4K H264/H265直播技术方案探讨
  6. lacp可以在access接口吗_【思唯网络学院】【干货】LACP与PAGP是什么?有何区别?...
  7. 一个黑色全屏的计时器_佳作分享最佳倒数计时器设计分析【附原型实例】
  8. 传播路径图调查2013年初
  9. maven 手动安装ojdbc7
  10. linux命令dstat,linux系统监控:dstat命令
  11. 【软件工程】结构图(SC)——期末复习用
  12. matlab 空集判定,在使用matlab 符号运算中的solve函数时,为啥计算的结果是空集?该怎么办?...
  13. Linux中shell的cat,linux shell cat 命令
  14. AR、BR、CR、SR 与 CE、PE、P概念整理
  15. 如何用计算机环境设计,计算机绘图软件在环境艺术设计中运用.doc
  16. python可以剪辑视频吗_你知道吗?Python也可以剪辑视频!
  17. Flink编程中遇到”scala.tools.reflect.ToolBoxError: reflective compilation has failed“的解决方法
  18. 猫,路由器,宽带(光纤,ADSL),带宽的区别和联系
  19. Unity间接光 ibl(基于图像的渲染)和SH(球谐光照)
  20. c类事业编计算机岗面试题,2017广西事业单位分类统考(C类)笔试试题答案

热门文章

  1. LEADTOOLS 20,识别,文档,医学,影像和多媒体技术
  2. 子弹短信内部技术分享:Redis
  3. Vue elementUI中把数据库中的1,0转成男女
  4. 【视频集】iPhone X 开箱+评测视频汇总(主流媒体)
  5. 全球第一经典语录,被500万人疯狂转载!!!
  6. CF 1742C 题解
  7. android 手势旋转,Android检测旋转手势
  8. ElasticSearch性能调优
  9. mac 下 qq截图突然不能用了
  10. 笔记木计算机自动关机怎么办,笔记本电脑突然自动关机怎么办