码迷,mamicode.com
首页 > 其他好文 > 详细

记录一次Tomcat内存泄露原因的追溯

时间:2016-07-13 19:35:04      阅读:93      评论:0      收藏:0      [点我收藏+]

标签:

  • 现象:WEB无法访问、SSH无法登陆、桌面登陆验证失败。
  • 重启服务器后登陆正常。
  • cat /var/log/message显示root用户创建了2000多个sessions后显示内存不足。
  • 进入tomcat安装目录(~/home/tomcat7_X/logs/)查看日志localhosts_time.log。发现如下错误:

     

java.lang.OutOfMemoryError: unable to create new native thread
at java.lang.Thread.start0(Native Method)
at java.lang.Thread.start(Thread.java:714)

 

  • 通过以上信息基本可以判定,由于tomcat创建的过多sessions,导致系统内存不足。产生如上问题。
  • 可以通过在~/home/tomcat7_X/目录中的catalina.sh文件中在” echo Using CATALINA_BASE:   %CATALINA_BASE%” 
    前加上: 
    set JAVA_OPTS=%JAVA_OPTS% -server -Xms4096m -Xmx4096m -XX:PermSize=128M 
    -XX:MaxPermSize=256m -XX:NewSize=256m -XX:MaxNewSize=512m

     

     

系统厂商可以在源码中使用线程池限定sessions个数来完成。

原来厂商以为JAVA会自己回收,结果木有……

 

 

参考资料:

http://jzhihui.iteye.com/blog/1271122

记录一次Tomcat内存泄露原因的追溯

标签:

原文地址:http://www.cnblogs.com/flankershen/p/5667137.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!