问题:
最近做项目碰到了让我纠结的问题,tomcat服务器运行一段时间,总是会自动报异常:Java.lang.OutOfmemoryError: PermGen Space 的错误,导致项目无法正常运行。
介绍:
PermGen Space:指的是内存的永久保存区,该块内存主要是被JVM用来存放 class 和 mete 信息的,当 class 被加载 loader 的时候就会被存储到该内存区中,与存放类的实例的heap区不同,java中的 垃圾回收器GC 不会在主程序运行期对 PermGen space 进行清理。
原因:
当我们的应用中有很多的class时,很可能就会出现PermGen space的错误。
我们的 tomcat 在重启的时候,不是使用的 ./bin/shutdown.sh 而是使用 kill -9 xxx 直接杀掉,这样的话,存在 PermGen space 里面的内存不会被释放的,这样多长进行 kill 之后,就会导致系统的内存被渐渐吃完了,直到最后 tomcat 报错。
解决方法:
手动设置MaxPermSize的大小
1.修改 TOMCAT_HOME/bin/catalina.bat文件
在echo "using CATALINA_BASE:$CATALINA_BASE"上面加入这一行内容:
set JAVA_OPTS=%JAVA_OPTS% -server -XX:PermSize=128m -XX:MaxPermSize=512m
2.如果是 linux 环境,则修改 TOMCAT_HOME/bin/catalina.sh:
JAVA_OPTS="$JAVA_OPTS" -server -XX:PermSize=128m -XX:MaxSize=512m
2.修改 TOMCAT_HOME/bin/catalina.bat文件的内容:
在 %_EXECJAVA% %JAVA_OPTS% 后面添加 -Xms=256m -Xmx512m
注意:前后后有空格的
例如: %_EXECJAVA% %JAVA_OPTS% -Xms=256m -Xmx512m(空格)后面的内容不变
在关闭重启 tomcat 的过程中使用 shutdown.sh 而不是 使用 kill -9
如果使用 shutdown.sh 不能将 tomcat 关掉的话,就必须要使用 kill -9 来关闭了,这个时候只有手动的来回收垃圾了: 在 linux 命令下执行如下的命令,把 缓存给丢弃掉。
echo 3 > /proc/sys/vm/drop_caches