Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2824832
  • 博文数量: 587
  • 博客积分: 6356
  • 博客等级: 准将
  • 技术积分: 6410
  • 用 户 组: 普通用户
  • 注册时间: 2008-10-23 10:54
个人简介

器量大者,福泽必厚

文章分类

全部博文(587)

文章存档

2019年(3)

2018年(1)

2017年(29)

2016年(39)

2015年(66)

2014年(117)

2013年(136)

2012年(58)

2011年(34)

2010年(50)

2009年(38)

2008年(16)

分类: LINUX

2013-03-28 14:41:46

今天公司CMS的tomcat又挂掉了,之前挂了一次.出现以下错误,后来把tomcat的内存增大到1024
严重: Exception initializing page context
.lang.OutOfMemoryError: Java heap space

在tomcat\bin\catalina.bat的set CURRENT_DIR=%cd% 前面添加
      set JAVA_OPTS =-Xms512m -Xmx1024m
      意思:设置最小虚拟内存512,最大1024.

今天tomcat又挂了,一查之下,发现内存只升不降,久而久之,系统就挂死了.另外你可以用java的一个管理工具查看内存使用情况.在jdk1.6.0\bin\jconsole.exe.

   总结下内存只升不降的几个原因:
   1.在java中虽然有垃圾回收器,但是对rs等通过jdbc访问的所产生的垃圾,它并不回收!
    2.是否是循环套接层数太多导致资源得不到释放,或者存在死循环,后者的可能性恨大。
    3.Tomcat 不支持EJB组件的开发,做j2ee项目时,最好还是用weblogic服务,而且在做基本的sql语句时,
最好用连接池,不要多用jdbc,odbc桥,因为在建立连接时最耗时间

     解决方法是让tomcat自己管理内存,在startup.bat的@echo off下面添加以下代码:
set  JAVA_OPTS=%JAVA_OPTS% -Dcom.sun.management.jmxremote.port=1090  -Dcom.sun.management.jmxremote.ssl=false  -Dcom.sun.management.jmxremote.authenticate=false  -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager  -Djava.util.logging.config.file="%CATALINA_HOME%\conf\logging.properties"

     然后再启动startup.bat,tomcat就会自己管理内存了.
    
     另外事实上,这是一个优化。因为对于,请求内存的系统调用会占用大量的cpu时间,所以频繁的请求、释放内存将会导致性能的严重下降。所以对于jvm,最好的方式就是尽量多占用内存作为heap,少释放甚至不释放空闲的heap给操作系统以减少消耗在内存请求、释放操作上的cpu时间。
        PermGen space的全称是Permanent Generation  space,是指内存的永久保存区域OutOfMemoryError: PermGen  space从表面上看就是内存益出,解决方法也一定是加大内存。说说为什么会内存益出:这一部分用于存放Class和Meta的信息,Class在被 Load的时候被放入PermGen space区域,它和和存放Instance的Heap区域不同,GC(Garbage  Collection)不会在主程序运行期对PermGen  space进行清理,所以如果你的APP会LOAD很多CLASS的话,就很可能出现PermGen space错误。这种错误常见在服务器对JSP进行pre compile的时候。

改正方法:-Xms256m -Xmx256m -XX:MaxNewSize=256m -XX:MaxPermSize=256m



阅读(2413) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~