tomcat内存溢出

tomcat其初始空间(即-Xms)是物理内存的1/64,最大空间(-Xmx)是物理内存的1/4。

可通过如下设置:

在catalina.bat中添加如下设置:

set JAVA_OPTS=-Xms128m -Xmx350m


在catalina.sh中添加如下设置:

JAVA_OPTS=-Xms128m -Xmx350m


-Xms:初始值

-Xmx:最大值

-Xmn:最小值

-XX:PermSize=永久内存最小值

-XX:MaxPermSize=永久内存最大值

-XX:MaxNewSize=JAVA堆区域新生代内存的最大可分配大小


设置好后通过startup.bat或startup.sh启动tomcat即可生效。


常见的tomcat错误有:

1.java.lang.OutOfMemoryError: Java heap space 

错误说明:该错误是JVM可以调配使用的内存空间不足导致的。是heap(存放实例的区域)不足。


错误分析:Heap size 的大小是Young Generation 和Tenured Generaion 之和。 在JVM中如果98%的时间是用于GC且可用的Heap size 不足2%的时候将抛出此异常信息。

 
提示:Heap Size 最大不要超过可用物理内存的80%,一般的要将-Xms和-Xmx选项设置为相同,而-Xmn为1/4的-Xmx值


解决方案:

在catalina.bat中添加如下设置:

set JAVA_OPTS=-Xms128m -Xmx350m


在catalina.sh中添加如下设置:

JAVA_OPTS=-Xms128m -Xmx350m


2.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)那么就会产生此错误信息了。 

解决方案:

在catalina.bat中添加如下设置:

set JAVA_OPTS=-XX:PermSize=128M -XX:MaxPermSize=512m


在catalina.sh中添加如下设置:

JAVA_OPTS=-XX:PermSize=128M -XX:MaxPermSize=512m


例如:

tomcat内存溢出_第1张图片


sun jdk gc的划分

young generation: 
  生命周期很短的对象,归为young generation。由于生命周期很短,这部分对象在gc的时候,很大部分的对象已经成为非活动对象。因此针对young generation的对象,采用copy算法,只需要将少量的存活下来的对象copy到to space。存活的对象数量越少,那么copy算法的效率越高。

 
  young generation的gc称为minor gc。经过数次minor gc,依旧存活的对象,将被移出young generation,移到tenured generation(下面将会介绍)

young generation分为: 
   eden:每当对象创建的时候,总是被分配在这个区域 
   survivor1:copy算法中的from space 
   survivor2:copy算法中的to sapce (备注:其中survivor1和survivor2的身份在每次minor gc后被互换)minor gc的时候,会把eden+survivor1(2)的对象copy到survivor2(1)去。 


tenured generation: 
  生命周期较常的对象,归入到tenured generation。一般是经过多次minor gc,还 依旧存活的对象,将移入到tenured generation。(当然,在minor gc中如果存活的对象的超过survivor的容量,放不下的对象会直接移入到tenured generation) 
  tenured generation的gc称为major gc,就是通常说的full gc。

  采用compactiion算法。由于tenured generaion区域比较大,而且通常对象生命周期都比较常,compaction需要一定时间。所以这部分的gc时间比较长。 
  minor gc可能引发full gc。当eden+from space的空间大于tenured generation区的剩余空间时,会引发full gc。这是悲观算法,要确保eden+from space的对象如果都存活,必须有足够的tenured generation空间存放这些对象。 


Permanet Generation: 
  该区域比较稳定,主要用于存放classloader信息,比如类信息和method信息。 对于spring hibernate这些需要动态类型支持的框架,这个区域需要足够的空间。
 

你可能感兴趣的:(tomcat,GC,sun,内存溢出)