tomcat内存溢出总结_第1页
tomcat内存溢出总结_第2页
tomcat内存溢出总结_第3页
免费预览已结束,剩余1页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、tomcat 内存溢出总结在生产环境中 tomcat 内存设置不好很容易出现内存溢出。造成内存原因是 不一样的,当然处理方式也不一样。这里根据平时遇到的情况和相关资料进行一个总结。 常见的一般会有下面三 种情况:: heap space: PermGen space: unable to create new native thread.对于前两种情况, 在应用本身没有内存泄露的情况下可以用设置tomcat jvm参数来解决。( -Xms -Xmx -XX: PermSize-XX:MaxPermSize )最后一种可能需要调整操作系统和 tomcat jvm 参数同时调整才能达到目的。第一种

2、:是堆溢出。在JVM中如果98%的时间是用于GC且可用的Heap size不足2%的时候将 抛出此异常信息。没有内存泄露的情况下,调整-Xms -Xmx参数可以解决。-Xms:初始堆大小-Xmx:最大堆大小但堆的大小受下面三方面影响:1. 相关操作系统的数据模型( 32-bt 还是 64-bit )限制;( 32位系统下,一般限制在2G我在2003 server系统下(物理内存:4G和6Q jdk : ) 1612M, 64为操作系统对内存无限制。)2. 系统的可用虚拟内存限制;3. 系统的可用物理内存限制。堆的大小可以使用 java -Xmx*M version 命令来。支持的话会出现 jd

3、k的版本号,不支持会报错。-Xms -Xmx 一般配置成一样比较好比如 set JAVA_OPTS= -Xms1024m -Xmx1024m第二种:永久保存区域溢出PermGenspace的全称是Perma nent Gen erati on space,是指内存的永久保存 区域。这一部分用于存放 Class 和 Meta 的信息 ,Class 在被 Load 的时候被放入 PermGenspace域,它和和存放 Instanee 的 Heap区域不同,GC(Garbage Collection) 不会在主程序运行期对PermGenspace进行清理,所以如果你的APP 会LOAD艮多CLAS

4、S勺话,就很可能出现PermGenspace错误。这种错误常见在 web 对JSP进行precompile的时候。但目前的hibernate 和spring 项目中也很容易 出现这样的问题。 (具体连接内容见下)的帖子有讨论的这个问题。可能是由 于这些框架会动态class,而且jvm的gc是不会清理PemGeispace的,导致内 存溢出。这一个一般是加大 -XX: PermSize -XX:MaxPermSize 来解决问题。-XX: PermSize 永久保存区域初始大小-XX: PermSize 永久保存区域初始最大值这一般结合第一条使用,比如 set JAVA_OPTS= -Xms10

5、24m-Xmx1024m -XX: PermSize=128M -XX: PermSize=256M有一点需要注意: java -Xmx*M version 命令来测试的最大堆内存是-Xmx与-XX: PermSize 的和 比如系统支持最大的jvm堆大小事,那 -Xmx1024m -XX: PermSize=768M 是无法运行的。第三种:无法创建新的线程。这种现象比较少见,也比较奇怪,主要是和 jvm 与系统内存的比例有关。这种怪事是因为JVM已经被系统分配了大量的内存(比如,并且它至少要占 用可用内存的一半。有人发现,在线程个数很多的情况下,你分配给JVM的内存 越多,那么,上述错误发生

6、的可能性就越大。产生这种现象的原因如下(从这个 blog 中了解到原因:.):每一个32位的进程最多可以使用2G的可用内存,因为另外2G被操作系统保留。这里假设使用给JVM那么还余下500M可用内存。这500M内存中的一部分必须用于系统dll的加载,那么真正剩下的也许只有 400M现在关键的地方出现了:当你使用创建一个线程,在JVM的内存里也会创 建一个 Thread 对象,但是同时也会在操作系统里创建一个真正的物理线程 (参考 JVM规范),操作系统会在余下的400兆内存里创建这个物理线程,而不是在JVM 的1500M的内存堆里创建。在里头,默认的栈大小是 256KB但是在里头,默认 的栈大

7、小为1M每线程,因此,在余下400M的可用内存里边我们最多也只能创建 400 个可用线程。这样结论就出来了,要想创建更多的线程,你必须减少分配给JVM的最大内 存。还有一种做法是让JVM宿主在你的JNI代码里边。给出一个有关能够创建线程的最大个数的估算公式:(MaxProcessMemory- JVMMemory- ReservedOsMemory)/ (ThreadStackSize) = Number of threads对于而言,假设操作系统保留120 M内存:JVM: /(1MB) = 380 threadsJVM: /(1MB) = 880 threads在 2000/XP/2003

8、 的里头有一个启动选项,好像是: /PAE /3G ,可以让用户 进程最大内存扩充至3G,这时操作系统只能占用最多1G的虚存。那样应该可以 让JVM创建更多的线程。因此这种情况需要结合操作系统进行相关调整。因此:我们需要结合不同情况对 tomcat 内存分配进行不同的诊断才能从根 本上解决问题。动态类导致永久保存区域溢出的 jvm bugSUNJDK+Tomcat 运行服务的时候遇到问题, 服务器跑几天后就会挂掉, 并报 PermGen space 异常。发现很多人把问题归因于: spring,hibernate,tomcat ,因为他们动态产生类 , 导致 JVM 中的 permanent

9、heap 溢出 。然后解决方法众说纷纭,有人说升级 tomcat 版本到最新甚至 干脆不用 tomcat 。还有人怀疑 spring 的问题,在 spring 论坛上讨论很激烈,因为 spring 在AOP时使用CBLIB会动态产生很多类。但问题是为什么这些王牌的开源会出现同一个问题呢,那么是不是更基础的原因呢tomcat在Q&A很隐晦的回答了这一点,我们知道这个问题,但这个问题是由一个更基础的 问题产生。于是有人对更基础的 JVM做了检查,发现了问题的关键。原来SUN的JVM把内存分了时候认为这个区域在 JVM启动的时候就固定了, 但他没有想到现在动态会用得这么广泛。而且这个区域有特殊的垃圾收回机制,现在的问题是动态加载类到这个区域后,gc 根本没办法回收!2003 年的时候就有一个 bug报告给sun,但是到现在,这个 bug还没有close !有人在这个 bug 加了句评语:“ A bug

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论