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

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

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

Java代码  

  1. JAVA_OPTS='-server -Xms1024m -Xmx1024m -XX:PermSize=128M -XX:MaxPermSize=256M -XX:NewSize=256m -XX:MaxNewSize=512m -XX:+UseParallelGC -XX:ParallelGCThreads=2 -XX:+UseAdaptiveSizePolicy'  
  2. JAVA_OPTS="$JAVA_OPTS  
  3. -Dcom.sun.management.jmxremote.port=8089  
  4. -Dcom.sun.management.jmxremote.ssl=false  
  5. -Dcom.sun.management.jmxremote.authenticate=false  
  6. -Djava.rmi.server.hostname=192.168.1.33  
  7. -Djava.util.logging.mannager=org.apache.juli.ClassLoaderLogManager  
  8. -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连接 
效果如图: 
tomcat增加jvisualvm监控

第四步:双击该JMX连接 

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

tomcat增加jvisualvm监控

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

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



 

相关文章:

  • 2021-12-15
  • 2021-06-02
  • 2022-02-19
猜你喜欢
  • 2021-09-27
  • 2021-09-09
  • 2021-05-07
  • 2021-10-18
相关资源
相似解决方案