Tomcat启动时报 java.lang.OutOfMemoryError: Java heap space

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Tomcat启动时报 java.lang.OutOfMemoryError: Java heap space相关的知识,希望对你有一定的参考价值。

见效的解决方法如下:
 

  在myeclipse中修改jvm启动的参数 打开Myeclipse -->windows-->preference-->myeclipse->server->找到tomcat下面的JDK在文本框中设置启动的参数 -Xms168m -Xmx512m

 

二、java.lang.OutOfMemoryError: Java heap space
Heap size 设置
JVM堆的设置是指java程序运行过程中JVM可以调配使用的内存空间的设置.JVM在启动的时候会自动设置Heap size的值,
其初始空间(即-Xms)是物理内存的1/64,最大空间(-Xmx)是物理内存的1/4。可以利用JVM提供的-Xmn -Xms -Xmx等选项可
进行设置。Heap size 的大小是Young Generation 和Tenured Generaion 之和。
提示:在JVM中如果98%的时间是用于GC且可用的Heap size 不足2%的时候将抛出此异常信息。
提示:Heap Size 最大不要超过可用物理内存的80%,一般的要将-Xms和-Xmx选项设置为相同,而-Xmn为1/4的-Xmx值。
解决方法:手动设置Heap size

这个问题的根源是jvm虚拟机的默认Heap大小是64M,可以通过设置其最大和最小值来实现.设置的方法主要是几个.

1.可以在windows 更改系统环境变量
加上JAVA_OPTS=-Xms64m -Xmx512m

2,如果用的tomcat,在windows下,可以在

C:/tomcat5.5.9/bin/catalina.bat? 中加上:

set JAVA_OPTS=-Xms64m -Xmx256m

位置在: rem Guess CATALINA_HOME if not defined? 这行的下面加合适.

3.如果是linux系统
Linux  在{tomcat_home}/bin/catalina.sh的前面,加
set JAVA_OPTS=‘-Xms64 -Xmx512‘

本人测试过 在tomcat安装目录下bin下的catalina.bat文件中添加 set JAVA_OPTS=-Xms64m -Xmx256m之后用myeclipse启动tomcat还会出现之前的异常。查了资料才知道:
 tomcat提供了两种安装模式,即免安装(*.zip)和安装(*.exe)方式。针对不同的安装方式下修改tomcat内存大小的方法几注意问题(windows环境):
   方式1:当选择安装方式时,可以在安装tomcat的过程进行设置tomcat初始化内存的大小。但是假如说在安装时没有选择,或者应用改变了,需要增加 tomcat内存时怎么半呢?此时,我们就要手工修改tomcat的一些文件了:        看了很多网上的资料,都是说修改/bin/catalina.bat文件的内容,即在里面增加一行代码:        set JAVA_OPTS=-Xms512m -Xmx512m //表示初始化最小可用内存和最大可用内存都是512MB(修改相应值即可)如在catalina.bat的
     rem ----- Execute The Requested Command ---------------------------------------
     echo Using CATALINA_BASE:    ?TALINA_BASE%
     echo Using CATALINA_HOME:    ?TALINA_HOME%
     echo Using CATALINA_TMPDIR: ?TALINA_TMPDIR%
     echo Using JAVA_HOME:        %JAVA_HOME%
这一栏改为
    rem ----- Execute The Requested Command ---------------------------------------
   set JAVA_OPTS=-Xms512m -Xmx512m
    echo Using CATALINA_BASE:    ?TALINA_BASE%
    echo Using CATALINA_HOME:    ?TALINA_HOME%
    echo Using CATALINA_TMPDIR: ?TALINA_TMPDIR%
    echo Using JAVA_HOME:        %JAVA_HOME%
就可以将JAVA虚拟机分配内存   508.0625MB的!
但 是很多人修改后,发现修改并没有起作用,即通过windows的服务启动tomcat时,实际的内存还是默认的,修改的设置并没有起作用;而通过/bin /startup.bat 启动却是生效的。这是为什么呢?因为在安装过程中,JVM的初始化参数已经写在注册表中了,由于没有修改注册表中相关参数,所以以windows服务方式 启动时,修改的并没有生效。而通过/bin/startup.bat 启动直接是通过/bin/catalina.bat文件中的配置的。你需要重新加载到系统服务中才生效,或者你手工在注册表中查找修改启动值,加载到服务 中的时候参数已经配置好了,自己修改artup.bat不会改变注册表中的参数设置。解决方法:修改注册表中的参数,加入JVM初始化内存的参 数:HKEY_LOCAL_MACHINE/SOFTWARE/Apache Software Foundation/Tomcat Service Manager/Tomcat5/Parameters/JavaOptions
值为
-Dcatalina.home="C:/ApacheGroup/Tomcat 5.0"
-Djava.endorsed.dirs="C:/ApacheGroup/Tomcat 5.0/common/endorsed"
-Xrs
如加入 -Xms512m -Xmx800m
     方式2:针对免安装的用户,也可以通过将tomcat注册为windows的一个服务的方式来实现:太麻烦了 还是不采用这种方式。

三、java.lang.OutOfMemoryError: PermGen space

PermGen space的全称是Permanent Generation space,是指内存的永久保存区域,
这块内存主要是被JVM存放Class和Meta信息的,Class在被Loader时就会被放到PermGen space中,
它和存放类实例(Instance)的Heap区域不同,GC(Garbage Collection)不会在主程序运行期对
PermGen space进行清理,所以如果你的应用中有很多CLASS的话,就很可能出现PermGen space错误,
这种错误常见在web服务器对JSP进行pre compile的时候。如果你的WEB APP下都用了大量的第三方jar, 其大小
超过了jvm默认的大小(4M)那么就会产生此错误信息了。
解决方法: 手动设置MaxPermSize大小

修改TOMCAT_HOME/bin/catalina.bat
在“echo "Using CATALINA_BASE:   $CATALINA_BASE"”上面加入以下行:
JAVA_OPTS="-server -XX:PermSize=64M -XX:MaxPermSize=128m
建议:将相同的第三方jar文件移置到tomcat/shared/lib目录下,这样可以达到减少jar 文档重复占用内存的目的。


还是建议采用在myeclipse中修改jvm启动的参数OK

以上是关于Tomcat启动时报 java.lang.OutOfMemoryError: Java heap space的主要内容,如果未能解决你的问题,请参考以下文章

tomcat启动时报错

idea中tomcat启动时报错

Tomcat在启动时报1099端口被占用的解决办法

tomcat启动时报以下三个严重错误

使用maven的tomcat插件启动时报错问题

Tomcat启动时报 java.lang.OutOfMemoryError: Java heap space