在tomcat上部署战争时OutOfMemory

时间:2013-11-25 18:31:17

标签: java tomcat grails out-of-memory

当我尝试在tomcat服务器上部署战争(使用'grails war'构建)时,我收到以下错误。遗憾的是,除了以下内容之外,日志文件中没有其他消息:

Nov 25, 2013 3:44:54 PM org.apache.tomcat.util.modeler.BaseModelMBean invoke
SEVERE: Exception invoking method check
java.lang.OutOfMemoryError: Java heap space
    at java.io.DataInputStream.readUTF(DataInputStream.java:661)
    at java.io.DataInputStream.readUTF(DataInputStream.java:564)
    at org.apache.tomcat.util.bcel.classfile.ConstantUtf8.<init>(ConstantUtf8.java:47)
    at org.apache.tomcat.util.bcel.classfile.Constant.readConstant(Constant.java:125)
    at org.apache.tomcat.util.bcel.classfile.ConstantPool.<init>(ConstantPool.java:60)
    at org.apache.tomcat.util.bcel.classfile.ClassParser.readConstantPool(ClassParser.java:209)
    at org.apache.tomcat.util.bcel.classfile.ClassParser.parse(ClassParser.java:119)
    at org.apache.catalina.startup.ContextConfig.processAnnotationsStream(ContextConfig.java:2118)
    at org.apache.catalina.startup.ContextConfig.processAnnotationsJar(ContextConfig.java:1994)
    at org.apache.catalina.startup.ContextConfig.processAnnotationsUrl(ContextConfig.java:1960)
    at org.apache.catalina.startup.ContextConfig.processAnnotations(ContextConfig.java:1945)
    at org.apache.catalina.startup.ContextConfig.webConfig(ContextConfig.java:1319)
    at org.apache.catalina.startup.ContextConfig.configureStart(ContextConfig.java:878)
    at org.apache.catalina.startup.ContextConfig.lifecycleEvent(ContextConfig.java:376)
    at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119)
    at org.apache.catalina.util.LifecycleBase.fireLifecycleEvent(LifecycleBase.java:90)
    at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5322)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
    at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:901)
    at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:877)
    at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:633)
    at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:976)
    at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:541)
    at org.apache.catalina.startup.HostConfig.check(HostConfig.java:1461)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:606)
    at org.apache.tomcat.util.modeler.BaseModelMBean.invoke(BaseModelMBean.java:301)
    at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.invoke(DefaultMBeanServerInterceptor.java:819)
    at com.sun.jmx.mbeanserver.JmxMBeanServer.invoke(JmxMBeanServer.java:801)
    at org.apache.catalina.manager.ManagerServlet.check(ManagerServlet.java:1445)

如何获取有关此错误的更多信息?

注意:

  • grails应用程序在本地工作,没有任何问题
  • 其他grails应用程序在同一台服务器上运行没有问题(所有版本均为2.2.0,新版本为2.3)
  • 我已经尝试扩展内存堆......没有改进

谢谢

3 个答案:

答案 0 :(得分:0)

您使用的Tomcat版本是什么?例如,如果您运行Debian Wheezy框,则软件包中提供的版本为 7.0.28 。它有一些关于遍历类路径以扫描注释的严重错误(至少这是我在阅读关于SO和错误报告的其他几个问题后注意到的)。我认为它已经修复了〜 7.0.34 。我有一个完全相同的问题,并注意到在新版本上一切正常。

答案 1 :(得分:0)

1- Create setenv.sh in Tomcat(8||9)/bin/setenv.sh 

    export CATALINA_OPTS="$CATALINA_OPTS -Xms512m"
    export CATALINA_OPTS="$CATALINA_OPTS -Xmx2048m"
    export CATALINA_OPTS="$CATALINA_OPTS -XX:MaxPermSize=256m"

2- chamod a+x setenv.sh  
3- execute ./setenv.sh  
4- ./startup.sh

答案 2 :(得分:0)

在CATALINA_OPTS -XX:+HeapDumpOnOutOfMemoryError中将以下选项添加到setenv.sh中,当您的部署因OOM而失败时,它将打印堆转储,您可以使用JVisualVM或{{3}之类的实用程序进行分析}。调查堆转储后,您可以做出决定:

  • 解决导致内存不足的问题
  • 增加堆大小(通过设置MemoryAnalyzer),以防无法解决问题。