jboss 出现异常:
java.lang.OutOfMemoryError: PermGen space(jboss 4.2.3.GA)
在网上做了一番搜索得到一些相关的内容。
PermGen space的全称是Permanent Generation space,是指内存的永久保存区域OutOfMemoryError: PermGen space从表面上看就是内存益出,解决方法也一定是加大内存。说说为什么会内存益出:这一部分用于存放Class和Meta的信息,Class在被 Load的时候被放入PermGen space区域,它和和存放Instance的Heap区域不同,GC(Garbage Collection)不会在主程序运行期对PermGen space进行清理,所以如果你的APP会LOAD很多CLASS的话,就很可能出现PermGen space错误。这种错误常见在web服务器对JSP进行pre compile的时候。
改正方法,在 run.bat 中加入:-Xms256m -Xmx512m -XX:MaxNewSize=256m -XX:MaxPermSize=256m
因为项目中引用了很多的 jar 包,而这些 jar 包中的 class 信息会被 JBoss 的 class loader 加载到 PermGen space 区域,在 JVM 默认的情况下,该部分空间的大小只有 4M,在 jar 包非常多的情况下,显然是不够用的,所以通过 -XX:MaxPermSize=256m 指定最大值后即可解决问题。
另外,如果 heap 内存不足出现 java.lang.OutOfMemoryError: Java heap space 时,可以通过 -Xmx512m 指定最大 heap 内存来解决这样的问题。
最终解决:
1. 如果你是以命令行模式或者直接点击“ run.bat ”来运行 JBoss ,那你就要在 bin/run.bat 文件中对 JVM 选项作修改了,找到 set JAVA_OPTS=% JAVA_OPTS % 这一段,然后在后面加上 -Xms256m -Xmx512m -XX:MaxNewSize=256m -XX:MaxPermSize=256m 。保存就 OK 了。
修改run.bat
if not "%JAVAC_JAR%" == "" set RUNJAR=%JAVAC_JAR%;%RUNJAR%
if "%JBOSS_CLASSPATH%" == "" set RUN_CLASSPATH=%RUNJAR%
if "%RUN_CLASSPATH%" == "" set RUN_CLASSPATH=%JBOSS_CLASSPATH%;%RUNJAR%
set JBOSS_CLASSPATH=%RUN_CLASSPATH%
rem Setup JBoss specific properties
set JAVA_OPTS=%JAVA_OPTS% -Dprogram.name=%PROGNAME%
rem Add -server to the JVM options, if supported
"%JAVA%" -server -version 2>&1 | findstr /I hotspot > nul
if not errorlevel == 1 (set JAVA_OPTS=%JAVA_OPTS% -server)
rem JVM memory allocation pool parameters. Modify as appropriate.
set JAVA_OPTS=%JAVA_OPTS% -Xms256m -Xmx512m -XX:MaxNewSize=256m -XX:MaxPermSize=512m
2. 在 Eclipse 中运行 Jboss 时,时间太长可能有时候会出现 java.lang.OutOfMemoryError : PermGen space 的错误,解决方法:
1.
点击debug图标旁边的小箭头;
2. 点击 ”Debug Configurations…” 菜单项;
3. 选左边的“Generic Server”树下面的“ JBoss v4.2 at localhost ”;
4. 点击右边的“ Arguments ” Tab 页签,在“ VM arguments ”中添加:-Xms128m -Xmx512m -XX:PermSize=64m -XX:MaxPermSize=512m
-Djboss.home=E:"/server/jboss-4.2.3.GA" -Djava.library.path=C:"/Java/jdk1.5.0_22/bin" -Djava.endorsed.dirs=E:"/server/jboss-4.2.3.GA/lib/endorsed" -Xms128m -Xmx512m -XX:PermSize=64m -XX:MaxPermSize=512m