zoukankan      html  css  js  c++  java
  • 记录一次Tomcat内存泄露原因的追溯

    • 现象: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

    当你觉得自己的想法很创新时,十有八九是知识面太窄。
  • 相关阅读:
    WinForm常用代码
    XML编程与应用-读取XML
    基础SQL语句
    WPF基础——继承
    wpf控件
    手机网页支付
    Application_Start 多次启动问题
    更改Outlook 2013中Exchange数据文件存放路径
    MySql双机热备份
    图片轮播(Jquery)
  • 原文地址:https://www.cnblogs.com/flankershen/p/5667137.html
Copyright © 2011-2022 走看看