`
pengjj2
  • 浏览: 136151 次
  • 性别: Icon_minigender_1
  • 来自: 无锡
社区版块
存档分类
最新评论

tomcat7内存溢出错误的一些原因和解决方案

 
阅读更多



 今天在做公司一个工程2个版本的运行时,突然出现新版的工程在tomcat中内存溢出。

 

因为错误比较明显,但也经过了一些折腾。

 

我的tomcat版本为最新的7.0.34,eclipse为3.7

 

在tomcat的wiki上其实对内存溢出和内存错误已经有一定的分析和说明

 

tomcat内存出错的一些原因:

 

1、建立的过多的对象,导致堆区内存不足

 

2、有代码被对象持有而导致垃圾收集器无法清理

 

3、超过了系统文件的大小限制,这样你需要提高你的权限或者用一个不受限制的。

 

4、你工程的线程数目过多,某些系统在同一个进程里对线程数目有限制,去看系统文档,和学习怎么提高这个数目

 

5、系统也许限制了你的进程的内存大小

 

6、JVM有bug,一般在低版本的jvm才出现

 

还介绍了内存溢出的一些常见处理方式

 

1、如果发现一个servlet装载大量的内容进入内存,你应该检查下你的代码是不是有bug

 

2、手动增加堆内存,导致没有空间去创建必须创建的那些线程所需要的栈空间,每个系统对线程创建所要消耗的栈默认不太相同,但是基本都高于2M,而且这个不能通过设置-Xss去减少

所以有一个规则,在32位系统下,对堆内存的分配一般不超过1024M

 

3、深度递归算法会导致内存出问题,因为方法信息都在栈中,所以一个可以用-Xss增加栈空间,另一个最好去优化你的算法

 

4、加载了大量的jar包或者同时维持几个项目将消耗你的非堆内存,在这种情况下-XX:MaxPermSize 去增加你的非堆内存

 

5、强引用导致垃圾收集器无法回收内存。可能会出现jsp重编译,工程重新加载,这将消耗大量时间,只到非堆内存得到清理或者内存溢出。

 

我今天的tomcat抛出的就是非堆内存溢出,可能是因为新的版本又加了一些jar包的缘故。

 

处理过程

 

第一次折腾:在tomcat\bin\catalina.bat 中 set JAVA_OPTS=%JAVA_OPT% -server -XX:PermSize=128m -XX:MaxPermSize=1024m

 

或者直接写 set JAVA_OPTS= -XX:PermSize=128m -XX:MaxPermSize=1024m

 

直接在tomcat启动,OK,工程正常启动

 

但是发现eclipse不认账

 

第二次折腾,打开 open launch configuration

点击Arguments选项卡

VM arguments 中添加

 

-Xms128m -Xmx1024m -XX:PermSize=128m -XX:MaxPermSize=1024

 

OK,解决完毕

  • 大小: 76.5 KB
1
0
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics