天天看点

多项目导致Tomcat以服务启动内存溢出报错“PermGen space”

使用Tomcat作为并将其注册为Windows系统服务时,当Tomcat的webapps下的项目比较多的时候,重启服务器后,会发现在Windows服务列表中明明显示服务已启动,但是访问Tomcat主页发现仍然无法访问,说明服务根本没有启动,且去tomcat的logs目录下去查找tomcat6-stdout.2015-12-17.log日志时,发现报错信息为java.lang.OutOfMemoryError: PermGen space。

此时,直接在服务中选择停止时,还有可能报错“Windows无法停止本机的tomcat服务,错误代码1053之类的”说明启动时已经出现错误,此时只能通过任务管理器,将tomcat6w.exe的进程关闭才可以。而且如果查找资料修改了catalina.bat中

set JAVA_OPTS=%JAVA_OPTS% -Xms512m -Xmx512m -XX:PermSize=128M

-XX:MaxNewSize=256m -XX:MaxPermSize=512m %LOGGING_CONFIG%

的配置之后,选择startup.bat是可以正常启动的,唯独作为服务不可以。那么,说明,catalina.bat中的参数值对执行脚本时有用。

发生此类错误的原因是由于,太多的项目引用第三方jar包,而很多jar包是重复的,比如log4j,比如spring的那么多jar包。而这些jar在tomcat启动的时候需要加载到内存中,默认的配置无法容纳之后出现内存溢出,解决的办法有:

  1. 修改当tomcat注册为服务之后的jvm的注册列表的相关配置项
  2. 将所有web工程的项目中WEB-INF下的lib下的jar统一剪切到tomcat的安装目录中的lib中。

分别给出具体操作步骤:

具体操作:首先需要注意的是,当在将tomcat安装为系统服务的时候,运行命令提示符(即cmd窗口),要通过以系统管理员身份运行。否则,可能会导致之后修改完参数报错,错误代码为4;当以服务安装完并配置为自动启动之后,需要到注册列表中找到如下选项进行配置。

  • 打开注册列表编辑器,找到如下位置HKEY_LOCAL_MACHINE\SOFTWARE\Apache Software Foundation\Procrun 2.0\tomcat6\Parameters\Java(Win7 X64系统则位于HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Apache Software Foundation\Procrun 2.0\tomcat6\Parameters\Java) ;
    多项目导致Tomcat以服务启动内存溢出报错“PermGen space”
  • 双击右侧窗口的“Options”键值,添加如下行:
    -XX:PermSize=256M
    -XX:MaxPermSize=512M 
    修改JvmMs,十进制为1024
    JvmMx,十进进制为2048
               
    具体修改多少合适请视服务器配置来定。如果是eclipse的tomcat插件启动tomcat,在“window”菜单-“Preferences”-“Tomcat”-“JVM Settings”中添加JVM参数如下即可:
    -Xms1024M -Xmx2048M -XX:PermSize=256M -XX:MaxPermSize=512M 
               
    如果是以命令行启动,在需要在catalina.bat的
    set JAVA_OPTS=-Xms1024m -Xmx2048m -XX:PermSize=256m -XX:MaxPermSize=512m
               
  • 最后建议修改完配置之后,还是把所有需要用到的jar包放到tomcat中我们自己的目录下,操作如下:

    在apache-tomcat-6.0.37\根目录下新建一个文件夹(extra-lib),并将提取的jar包放到extra-lib下;修改apache-tomcat-6.0.37\conf\catalina.properties文件,在其中添加如下代码:

    shared.loader=${catalina.base}/extra-lib,${catalina.base}/extra-lib/*.jar