在tomcat上部署战争的OutOfMemory

问题描述 投票:1回答:3

当我尝试在雄猫服务器上部署战争(使用'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上)
  • 我已经尝试扩展内存堆...没有任何改善

谢谢

java tomcat grails out-of-memory
3个回答
0
投票

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


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

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

    解决导致内存不足的问题
  • 如果无法解决问题,则增加堆大小(通过设置-Xmx in CATALINA_OPTS)。
© www.soinside.com 2019 - 2024. All rights reserved.