文档章节

tomcat cpu暴涨的原因之一及其解决方法

 博爱飞扬
发布于 2017/05/06 10:31
字数 523
阅读 27
收藏 0

当你使用tomcat部署web系统时,过了一段时间发现cpu暴涨,你不防试试下面的方法,看看是否程序内的死循环导致cpu暴涨。 

第一步:增加tomcat监控对外端口 

在你的tomcat的bin目录下找到catalina.sh在二行加上 

Java代码  收藏代码

JAVA_OPTS='-server -Xms1024m -Xmx1024m -XX:PermSize=128M -XX:MaxPermSize=256M -XX:NewSize=256m -XX:MaxNewSize=512m -XX:+UseParallelGC -XX:ParallelGCThreads=2 -XX:+UseAdaptiveSizePolicy'  

JAVA_OPTS="$JAVA_OPTS  

-Dcom.sun.management.jmxremote.port=8089  

-Dcom.sun.management.jmxremote.ssl=false  

-Dcom.sun.management.jmxremote.authenticate=false  

-Djava.rmi.server.hostname=192.168.1.33  

-Djava.util.logging.mannager=org.apache.juli.ClassLoaderLogManager  

-Djava.util.logging.config.file=$CATALINA_HOME/conf/logging.properties"  


注意修改为自己的ip和端口 
-Dcom.sun.management.jmxremote.port=8089//对外端口 
-Djava.rmi.server.hostname=192.168.1.33//为本机IP 

第二步:启动tomcat 

你懂得... 

第三步:开启jvisualvm监控 

在你本机jdk的bin目录下找到jvisualvm.exe,例如我的目录为C:\Program Files (x86)\Java\jdk1.6.0_33\bin\jvisualvm.exe 
a.双击运行程序 
b.选择远程 
c.添加远程主机,如:192.168.1.254 
d.选择该主机 
e.添加JMX连接 
效果如图: 


第四步:双击该JMX连接 

点击线程查看线程运行情况,一般只有main和一些监听程序一直是运行状态(runnable), 
加入你有http-80- 类似的线程也一直处于运行状态,那就说明该执行该http请求有问题,甚至是死循环。 
如图: 



这里的http-80-25很长一段时间都处于运行状态,注意:绿色带便运行状态 

第五步:点击上面图片标识的"线程dump",可以查看相信信息 

经查,我的详细信息为: 

Java代码  收藏代码

  1. "http-80-25" - Thread t@101  
  2.    java.lang.Thread.State: RUNNABLE  
  3.     at com.wondertek.service.impl.FileManage.getFileOrFolderInfo(FileManage.java:278)  
  4.     at com.wondertek.web.action.FileAction.getFileOrFolderList(FileAction.java:500)  
  5.     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)  
  6.     at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)  
  7.     at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)  
  8.     at java.lang.reflect.Method.invoke(Unknown Source)  



第六步:找到对应的程序 
发现代码确实出现了死循环 
代码如下: 

Java代码  收藏代码

  1. while (true) {  
  2.                 for (int i = 0; i < infoSearch.size(); i++) {  
  3.                     BasicDBObject infoDbObject = (BasicDBObject) infoSearch  
  4.                             .get(i);  
  5.                     globalFile = infoDbObject.getString(DBColConstants.m_id);  
  6.                     if (fileId.equals(globalFile)) {// 开始找上一层编号  
  7.                         fileId = infoDbObject  
  8.                                 .getString(DBColConstants.m_strParentID);// 下一个fileid  
  9.                         // infoDbObject.getString(fileId);  
  10.                         fileParentIds.add(infoDbObject  
  11.                                 .getString(DBColConstants.m_strParentID));  
  12.                         infoSearch.remove(i);  
  13.                         i--;  
  14.                     }  
  15.                 }  
  16.                 if (fileId.indexOf("@") > 0) {// 到根目录查找完成  
  17.                     break;  
  18.                 }  
  19.             }  



假如fileId不包含"@"符号,程序将陷入死循环。 

© 著作权归作者所有

粉丝 5
博文 28
码字总数 13760
作品 0
深圳
后端工程师
私信 提问
综合技术----线上环境内存暴涨或者CPU暴增问题排查

最近线上环境系统经常出现内存暴涨的现象,前段时间经常出现数据库服务器CPU暴增(经常100%)的情况。经过逐步排查,最终解决问题,先将解决过程记录下来。 解决内存暴涨步骤 1.排查报错日志 ...

求是科技
05/08
0
0
彻底找到 Tomcat 启动速度慢的元凶

问题现象 美女同事找我解决一个问题,说Tomcat启动很慢。开始我以为是程序写的问题,所以把webapps下所有程序都删除掉。(只保留Tomcat自带)灵异的事情发生了,Tomcat停止在—— 我查看了一...

MaxWell__
2018/04/26
0
0
tomcat + mongdb 内存 监控

使用tomcat 和 mongodb 的一些 内存情况, 贴出来帮我分析一下, 推荐一下 有 什么好的分析 工具可以使用的 tomcat 内存监控的 @红薯 总体的内存 PID USER PR NI VIRT RES SHR S %CPU %MEM TI...

panmingguang
2014/12/19
249
3
Google App Engine 新定价惹开发者愤怒

Google最近看起来麻烦不断啊,其近期为App Engine的定价并没有取得使用者的芳心,反而让他们很恼怒。虽然在调价之前举行了一个所谓的类似听证会一样的东西,但是跟中国的听证会一个结果,我要...

红薯
2011/09/03
2.2K
11
解决tomcat占用CPU过高

因生产环境tomcat占用CPU持续过高,负载过高,重启tomcat过于缓慢,参与网上资料,解决tomcat占用CPU过高,重启缓慢问题 1、通过top命令找出占用CPU高的PID top - 15:52:18 up 93 days, 2:23...

hbssliulei
2013/12/25
0
0

没有更多内容

加载失败,请刷新页面

加载更多

如何远程调试部署在CloudFoundry平台上的nodejs应用

网络上关于如何本地调试nodejs应用的教程已经很多了,工具有Chrome开发者工具,Visual Studio Code,和nodejs周边的一些小工具等等。 在实际情况中,我们可能遇到本地运行良好,但是部署到C...

JerryWang_SAP
24分钟前
0
0
微信扫码访问网站调用默认浏览器打开如何实现?

我们在微信内分享链接或二维码的时候,我们会发现我们的网站是可以在浏览器里正常打开的,但就是不能在微信里打开,提示 “ 已停止访问该网页 ”,无论是聊天框也一样。说是系统检测到您的网...

明尼苏达哈士奇
32分钟前
1
0
一份Java程序员进阶架构师的秘籍,你离架构师还差多远

一、如何定义架构师 Java架构师,首先要是一个Java程序员,熟练使用各种框架,并知道它们实现的原理。jvm虚拟机原理、调优,懂得jvm能让你写出性能更好的代码;池技术,什么对象池,怎么解决并...

我最喜欢三大框架
40分钟前
0
0
想说再见不容易,win7最新市占率依然超36%

微软正在通过努力让Windows 7用户升级至Windows 10,不过从目前的市占率来看,他们还是要加把劲了。 据最新的市场份额看,Windows 10在本月的市场份额有所提升,从43.62%增长到44.10%。另一...

linuxCool
52分钟前
4
0
SQL的优化

对查询进行优化,要尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引。 对查询进行优化,要尽量避免全表扫描,首先应考虑在进行条件判断的字段上创建了索引。 应尽量避...

咸鱼-李y
今天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部