zoukankan      html  css  js  c++  java
  • 【Tomcat】java.lang.OutOfMemoryError

    1.Java heap space Heap size

    昨天在服务器上面部署项目,之前服务器上面已经有一个项目的了。

    然后我再部署一个,上去跑了之后,居然内存溢出了。

    好吧,内存溢出就调一下,调了之后发现还是那样,点不到几下就挂了。

    后面折腾了一下午,因为我机子上面本地跑的是多少个都没问题的,

    我想了下,会不会是tomcat版本的问题,果断换了个tomcat上去,一换果然行了。

    郁闷,记录一下吧。

    下面是版本号:

    apache-tomcat-7.0.55:这个是出现内存溢出,修改内存还解决不了问题的版本。

    apache-tomcat-7.0.11:这个是不会内存溢出的版本。

    2.PermGen space

    PermGen space的全称是Permanent Generation space,是指内存的永久保存区域,

    这块内存主要是被JVM存放Class和Meta信息的,

    Class在被Loader时就会被放到PermGen space中,

    它和存放类实例(Instance)的Heap区域不同,

    GC(Garbage Collection)不会在主程序运行期对PermGen space进行清理,

    所以如果你的应用中有很CLASS的话,就很可能出现PermGen space错误,

    这种错误常见在web服务器对JSP进行pre compile的时候。

    如果你的WEB APP下都用了大量的第三方jar,

    其大小超过了jvm默认的大小(4M)那么就会产生此错误信息了。

    解决方法:

    1. 手动设置MaxPermSize大小

    修改TOMCAT_HOME/bin/catalina.bat(Linux下为catalina.sh),

    在“echo "Using CATALINA_BASE:$CATALINA_BASE"”上面加入以下行:

    set JAVA_OPTS=%JAVA_OPTS% -server -XX:PermSize=128M -XX:MaxPermSize=512m

    catalina.sh下为:

    JAVA_OPTS="$JAVA_OPTS -server -XX:PermSize=128M -XX:MaxPermSize=512m"

  • 相关阅读:
    数独游戏
    数据类型格式化函数(PostgreSQL),ORACLE支持
    DB2中有关日期和时间的函数,及应用
    XPath详解,总结(转)
    使用 DB2 Connect By 的分级查询(转)
    了解 DB2 Version 9.5 中的全局变量(转)
    DB2中游标的使用(转)
    如何启用和禁用oracle&DB2数据库外键约束(转)
    如何在 DB2 Universal Database 中暂时禁用触发器(转)
    DB2的一些常用SQL写法(转)
  • 原文地址:https://www.cnblogs.com/zengweiming/p/3994224.html
Copyright © 2011-2022 走看看