当你使用tomcat部署web系统时,过了一段时间发现cpu暴涨,你不防试试下面的方法,看看是否程序内的死循环导致cpu暴涨。
第一步:增加tomcat监控对外端口
在你的tomcat的bin目录下找到catalina.sh在二行加上
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",可以查看相信信息
经查,我的详细信息为:
"http-80-25" - Thread t@101
java.lang.Thread.State: RUNNABLE
at com.wondertek.service.impl.FileManage.getFileOrFolderInfo(FileManage.java:278)
at com.wondertek.web.action.FileAction.getFileOrFolderList(FileAction.java:500)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
第六步:找到对应的程序
发现代码确实出现了死循环
代码如下:
while (true) {
for (int i = 0; i < infoSearch.size(); i++) {
BasicDBObject infoDbObject = (BasicDBObject) infoSearch
.get(i);
globalFile = infoDbObject.getString(DBColConstants.m_id);
if (fileId.equals(globalFile)) {// 开始找上一层编号
fileId = infoDbObject
.getString(DBColConstants.m_strParentID);// 下一个fileid
// infoDbObject.getString(fileId);
fileParentIds.add(infoDbObject
.getString(DBColConstants.m_strParentID));
infoSearch.remove(i);
i--;
}
}
if (fileId.indexOf("@") > 0) {// 到根目录查找完成
break;
}
}
假如fileId不包含"@"符号,程序将陷入死循环。
最后,至于怎么解决我相信大家都懂了。
望大家指正。
原创,转载请留原址:http://joe-zhjiang.iteye.com/admin/blogs/1736626/edit
- 大小: 97.3 KB
- 大小: 80.1 KB
分享到:
相关推荐
setting.xml文件,修改Maven仓库指向至阿里仓
基于java的玉安农副产品销售系统的开题报告
dev-c++ 6.3版本
基于java的项目监管系统开题报告
基于springboot多彩吉安红色旅游网站源码数据库文档.zip
毕业设计&课设_基于 AFLFast 改进能量分配策略的毕业设计项目,含 Mix Schedule策略设计及测试结果分析.zip
基于springboot办公用品管理系统源码数据库文档.zip
C++调用qml对象Demo
非常漂亮的类Web界面的Delphi设计54ed7-main.zip
VB SQL车辆管理系统是一款基于Visual Basic(VB)编程语言和SQL数据库开发的综合车辆管理工具。该系统集成了车辆信息管理、驾驶员信息管理、车辆调度、维修记录、数据存储与检索、报告生成以及安全权限管理等多个核心功能模块。 源代码部分提供了详细的开发流程和实现方法,涵盖了从数据库设计、界面设计到事件驱动编程、数据访问技术和错误处理等关键技术点。通过该系统,用户可以方便地录入、查询、修改和删除车辆及驾驶员信息,实现车辆信息的实时更新和跟踪。同时,系统还支持生成各类车辆管理相关的报告,帮助用户更好地掌握车辆运营情况。 系统部分则采用了直观易用的用户界面设计,使得用户能够轻松上手并快速完成车辆管理工作。系统还具备强大的数据处理能力和安全性,通过数据备份和系统升级优化等功能,确保数据的完整性和系统的稳定运行。 总体而言,VB SQL车辆管理系统是一款功能全面、易于操作且安全可靠的车辆管理工具,适用于企业和个人进行日常车辆运营和管理。无论是车辆信息的录入、查询还是报告生成,该系统都能够提供高效、便捷的服务,是车辆管理工作的理想选择。
AutoSAR基础学习资源
基于springboot英语学习平台源码数据库文档.zip
数据集,深度学习,密封数据集,马体态数据集
基于java的数字家庭网站开题报告
podman使用国内源镜像加速器
基于springboot+web的留守儿童网站源码数据库文档.zip
基于springboot的智能宾馆预定系统源码数据库文档.zip
GetQzonehistory-main.zip
环境说明:开发语言:Java 框架:springboot JDK版本:JDK1.8 服务器:tomcat7 数据库:mysql 5.7 数据库工具:Navicat 开发软件:eclipse/myeclipse/idea Maven包:Maven 浏览器:谷歌浏览器。 项目经过测试均可完美运行
内容概要:本文档详细介绍了QST公司生产的QMI8A01型号的6轴惯性测量单元的数据表及性能参数。主要内容包括设备特性、操作模式、接口标准(SPI、I2C与I3C),以及各种运动检测原理和技术规格。文中还提到了设备的工作温度范围宽广,内置的大容量FIFO可用于缓冲传感器数据,减少系统功耗。此外,对于器件的安装焊接指导亦有详细介绍。 适合人群:电子工程技术人员、嵌入式开发人员、硬件设计师等。 使用场景及目标:适用于需要精准测量物体空间位置变化的应用场合,如消费电子产品、智能穿戴设备、工业自动化等领域。帮助工程师快速掌握该款IMU的技术要点和应用场景。 其他说明:文档提供了详细的电气连接图表、封装尺寸图解等资料,方便用户进行电路板的设计制作。同时针对特定应用提出了一些优化建议。