服务器

位置:IT落伍者 >> 服务器 >> 浏览文章

Tomcat内存溢出的原因


发布日期:2024年06月07日
 
Tomcat内存溢出的原因

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堆大小事GXmxm XXPermSize=M 是无法运行的

第三种无法创建新的线程

这种现象比较少见也比较奇怪主要是和jvm与系统内存的比例有关

这种怪事是因为JVM已经被系统分配了大量的内存(比如G)并且它至少要占用可用内存的一半

上一篇:SVN服务器端与Eclipse中的客户端配置详解

下一篇:在JBuilder+Tomcat下开发sturts