java web中的Exception in thread "ContainerBackgroundProcessor[StandardEngine[Catalina]]" java.lang.OutOfMemoryError: PermGen space
最近老是在運行eclipse的時候,出現這樣的問題:
1 Exception in thread "ContainerBackgroundProcessor[StandardEngine[Catalina]]" java.lang.OutOfMemoryError: PermGen space 2 at java.lang.ClassLoader.defineClass1(Native Method) 3 at java.lang.ClassLoader.defineClass(Unknown Source) 4 at java.security.SecureClassLoader.defineClass(Unknown Source) 5 at org.apache.catalina.loader.WebappClassLoader.findClassInternal(WebappClassLoader.java:2904) 6 at org.apache.catalina.loader.WebappClassLoader.findClass(WebappClassLoader.java:1173) 7 at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1681) 8 at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1559) 9 at com.opensymphony.xwork2.inject.ContainerImpl$5.create(ContainerImpl.java:311)10 at com.opensymphony.xwork2.inject.ContainerImpl$5.create(ContainerImpl.java:307)11 at com.opensymphony.xwork2.inject.util.ReferenceCache$CallableCreate.call(ReferenceCache.java:150)12 at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source)13 at java.util.concurrent.FutureTask.run(Unknown Source)14 at com.opensymphony.xwork2.inject.util.ReferenceCache.internalCreate(ReferenceCache.java:76)15 at com.opensymphony.xwork2.inject.util.ReferenceCache.get(ReferenceCache.java:116)16 at com.opensymphony.xwork2.inject.ContainerImpl.getConstructor(ContainerImpl.java:603)17 at com.opensymphony.xwork2.inject.ContainerBuilder$5.create(ContainerBuilder.java:204)18 at com.opensymphony.xwork2.inject.Scope$2$1.create(Scope.java:51)19 at com.opensymphony.xwork2.inject.ContainerBuilder$3.create(ContainerBuilder.java:93)20 at com.opensymphony.xwork2.inject.ContainerBuilder$7.call(ContainerBuilder.java:487)21 at com.opensymphony.xwork2.inject.ContainerBuilder$7.call(ContainerBuilder.java:484)22 at com.opensymphony.xwork2.inject.ContainerImpl.callInContext(ContainerImpl.java:580)23 at com.opensymphony.xwork2.inject.ContainerBuilder.create(ContainerBuilder.java:484)24 at com.opensymphony.xwork2.config.impl.DefaultConfiguration.createBootstrapContainer(DefaultConfiguration.java:288)25 at com.opensymphony.xwork2.config.impl.DefaultConfiguration.reloadContainer(DefaultConfiguration.java:205)26 at com.opensymphony.xwork2.config.ConfigurationManager.getConfiguration(ConfigurationManager.java:66)27 at org.apache.struts2.dispatcher.Dispatcher.init_PreloadConfiguration(Dispatcher.java:390)28 at org.apache.struts2.dispatcher.Dispatcher.init(Dispatcher.java:437)29 at org.apache.struts2.dispatcher.ng.InitOperations.initDispatcher(InitOperations.java:74)30 at org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter.init(StrutsPrepareAndExecuteFilter.java:51)31 at org.apache.catalina.core.ApplicationFilterConfig.initFilter(ApplicationFilterConfig.java:277)32 at org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:258)33 at org.apache.catalina.core.ApplicationFilterConfig.setFilterDef(ApplicationFilterConfig.java:382)
下面是圖片形式:
原因:
1 /** 2 * 原因如下: 3 * PermGen space的全稱是Permanent Generation space<br> 4 * 是指內存的永久保存區域,這塊內存主要是被JVM存放Class和Meta信息的<br> 5 * Class在被Loader時就會被放到PermGen space中<br> 6 * 它和存放類實例(Instance)的Heap區域不同,GC(Garbage Collection)<br> 7 * 不會在主程序運行期對PermGen space進行清理,所以如果你的應用中有很多CLASS的話<br> 8 * 就很可能出現PermGen space錯誤,這種錯誤常見在web服務器對JSP進行pre compile的時候<br> 9 * 如果你的WEB APP下都用了大量的第三方jar, 其大小超過了jvm默認的大小(4M)那麼就會產生此錯誤信息了<br>10 * 詳細:http://greemranqq.iteye.com/blog/170586711 */
解決方法:
1 解決方法1: 2 3 手動設置MaxPermSize大小,如果是linux系統,修改TOMCAT_HOME/bin/catalina.sh,如果是windows系統,修改TOMCAT_HOME/bin/catalina.bat, 4 在“echo "Using CATALINA_BASE: $CATALINA_BASE"”上面加入以下行: 5 JAVA_OPTS="-server -XX:PermSize=64M -XX:MaxPermSize=128m 6 7 ///////////////////////////////////////////////////////////////////////// 8 9 解決方法2: 10 修改eclipse.ini文件,修改如下:11 12 -vmargs13 -Dosgi.requiredJavaVersion=1.514 -Xms128m15 -Xmx512m16 -XX:PermSize=64M 17 -XX:MaxPermSize=128M18 19 如果還報錯,可以考慮如下修改20 21 -vmargs22 -Dosgi.requiredJavaVersion=1.523 -Xms512m24 -Xmx1024m25 -XX:PermSize=256M 26 -XX:MaxPermSize=512M
多數是採用第2中方法...修改了,就可以搞定啦....