当你使用tomcat部署web系统时,过了一段时间发现cpu暴涨,你不防试试下面的方法,看看是否程序内的死循环致使cpu暴涨。
第一步:增长tomcat监控对外端口
在你的tomcat的bin目录下找到catalina.sh在二行加上 java
Java代码 web
JAVA_OPTS='-server -Xms1024m -Xmx1024m -XX:PermSize=128M -XX:MaxPermSize=256M -XX:NewSize=256m -XX:MaxNewSize=512m -XX:+UseParallelGC -XX:ParallelGCThreads=2 -XX:+UseAdaptiveSizePolicy' apache
JAVA_OPTS="$JAVA_OPTS tomcat
-Dcom.sun.management.jmxremote.port=8089 .net
-Dcom.sun.management.jmxremote.ssl=false 线程
-Dcom.sun.management.jmxremote.authenticate=false server
-Djava.rmi.server.hostname=192.168.1.33 图片
-Djava.util.logging.mannager=org.apache.juli.ClassLoaderLogManager ip
-Djava.util.logging.config.file=$CATALINA_HOME/conf/logging.properties" ssl
注意修改成本身的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代码
第六步:找到对应的程序
发现代码确实出现了死循环
代码以下:
Java代码
假如fileId不包含"@"符号,程序将陷入死循环。