記錄一次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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM