多项目导致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) ;
  • 双击右侧窗口的“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

转载于:https://my.oschina.net/vshcxl/blog/1512243

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值