Tomcat内存释放不了、Tomcat内存溢出原因

2年前 (2022) 程序员胖胖胖虎阿
274 0 0

公司的tomcat又挂掉了,之前挂了一次.出现以下错误,后来把tomcat的内存增大到1024  
严重: Exception initializing page context  java.lang.OutOfMemoryError: Java heap space  
   
  在tomcat\bin\catalina.bat的set CURRENT_DIR=%cd% 前面添加  
      set JAVA_OPTS =-Xms512m -Xmx1024m  
      意思:设置最小虚拟内存512,最大1024.  
  今天tomcat又挂了,一查之下,发现内存只升不降,久而久之,系统就挂死了.另外你可以用java的一个管理工具查看内存使用情况.在jdk1.6.0\bin\jconsole.exe.  
   
   总结下内存只升不降的几个原因:  

   1.在java中虽然有垃圾回收器,但是对rs等通过jdbc访问数据库的所产生的垃圾,它并不回收!  
    2.是否是循环套接层数太多导致资源得不到释放,或者存在死循环,后者的可能性恨大。  

     解决方法是让tomcat自己管理内存,在startup.bat的@echo off下面添加以下代码:  

set JAVA_OPTS=%JAVA_OPTS% 

-Dcom.sun.management.jmxremote.port=1090 

-Dcom.sun.management.jmxremote.ssl=false 

-Dcom.sun.management.jmxremote.authenticate=false 

-Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager 

-Djava.util.logging.config.file="%CATALINA_HOME%\conf\logging.properties"  

     然后再启动startup.bat,tomcat就会自己管理内存了.  
      
     另外事实上,这是一个优化。因为对于操作系统,请求内存的系统调用会占用大量的cpu时间,所以频繁的请求、释放内存将会导致性能的严重下降。所以对于 jvm,最好的方式就是尽量多占用内存作为heap,少释放甚至不释放空闲的heap给操作系统以减少消耗在内存请求、释放操作上的cpu时间。  
    

改正方法:-Xms256m -Xmx256m -XX:MaxNewSize=256m -XX:MaxPermSize=256m 

---------------------------------------------------------------------------------------------------------------------------------

先试试这个:
-Xms64m 
-Xmx256m 
-XX:PermSize=128M 
-XX:MaxNewSize=256m 
-XX:MaxPermSize=256m   

2、其次是:java.lang.OutOfMemoryError: PermGen space 

原因: 

PermGen space的全称是Permanent Generation space,是指内存的永久保存区域,这块内存主要是被JVM存放Class和Meta信息的,Class在被Loader时就会被放到PermGen space中,它和存放类实例(Instance)的Heap区域不同,GC(Garbage Collection)不会在主程序运行期对PermGen space进行清理,所以如果你的应用中有很CLASS的话,就很可能出现PermGen space错误,这种错误常见在web服务器对JSP进行pre compile的时候。如果你的WEB APP下都用了大量的第三方jar, 其大小超过了jvm默认的大小(4M)那么就会产生此错误信息了。 

解决方法: 

1. 手动设置MaxPermSize大小 
修改TOMCAT_HOME/bin/catalina.bat(Linux下为catalina.sh),在Java代码 
“echo "Using CATALINA_BASE: $CATALINA_BASE"”上面加入以下行:    
set JAVA_OPTS=%JAVA_OPTS% -server -XX:PermSize=128M -XX:MaxPermSize=512m   

“echo "Using CATALINA_BASE: $CATALINA_BASE"”上面加入以下行: 
set JAVA_OPTS=%JAVA_OPTS% -server -XX:PermSize=128M -XX:MaxPermSize=512m 

catalina.sh下为: 
Java代码 
JAVA_OPTS="$JAVA_OPTS -server -XX:PermSize=128M -XX:MaxPermSize=512m"  

JAVA_OPTS="$JAVA_OPTS -server -XX:PermSize=128M -XX:MaxPermSize=512m" 

 

版权声明:程序员胖胖胖虎阿 发表于 2022年11月12日 上午8:40。
转载请注明:Tomcat内存释放不了、Tomcat内存溢出原因 | 胖虎的工具箱-编程导航

相关文章

暂无评论

暂无评论...