Tomcat内存溢出的原因
在生产环境中tomcat内存设置不好很容易出现内存溢出造成内存原因是不一样的当然处理方式也不一样
这里根据平时遇到的情况和相关资料进行一个总结常见的一般会有下面三种情况
OutOfMemoryError Java heap space
OutOfMemoryError PermGen space
OutOfMemoryError unable to create new native thread
Tomcat内存溢出解决方案
对于前两种情况在应用本身没有内存洩露的情况下可以用设置tomcat jvm参数来解决(Xms Xmx XXPermSize XXMaxPermSize)
最后一种可能需要调整操作系统和tomcat jvm参数同时调整才能达到目的
第一种是堆溢出
在JVM中如果%的时间是用于GC且可用的 Heap size 不足%的时候将抛出此异常信息
没有内存洩露的情况下调整Xms Xmx参数可以解决
Xms初始堆大小
Xmx最大堆大小
但堆的大小受下面三方面影响
相关操作系统的数据模型(bt还是bit)限制(位系统下一般限制在G~G我在 server 系统下(物理内存G和Gjdk)测试 M为操作系统对内存无限制)
系统的可用虚拟内存限制
系统的可用物理内存限制
堆的大小可以使用 java Xmx***M version 命令来测试支持的话会出现jdk的版本号不支持会报错
Xms Xmx一般配置成一样比较好比如set JAVA_OPTS= Xmsm Xmxm
第二种永久保存区域溢出
PermGen space的全称是Permanent Generation space是指内存的永久保存区域这一部分用于存放Class和Meta的信息Class在被 Load的时候被放入PermGen space区域它和和存放Instance的Heap区域不同GC(Garbage Collection)不会在主程序运行期对PermGen space进行清理所以如果你的APP会LOAD很多CLASS的话就很可能出现PermGen space错误这种错误常见在web服务器对JSP进行pre compile的时候但目前的hibernate和spring项目中也很容易出现这样的问题可能是由于这些框架会动态class而且jvm的gc是不会清理PemGen space的导致内存溢出
这一个一般是加大XXPermSize XXMaxPermSize 来解决问题
XXPermSize 永久保存区域初始大小
XXPermSize 永久保存区域初始最大值
这一般结合第一条使用比如 set JAVA_OPTS= Xmsm Xmxm XXPermSize=M XXPermSize=M
有一点需要注意java Xmx***M version 命令来测试的最大堆内存是 Xmx与 XXPermSize的 和 比如系统支持最大的jvm堆大小事G那 Xmxm XXPermSize=M 是无法运行的
第三种无法创建新的线程
这种现象比较少见也比较奇怪主要是和jvm与系统内存的比例有关
这种怪事是因为JVM已经被系统分配了大量的内存(比如G)并且它至少要占用可用内存的一半