Tomcat 7.0.42 每天崩溃多次

Tomcat 7.0.42 每天崩溃多次

我正在运行一个 Tomcat7 服务器,它崩溃了并且有时会显示内存警告,提示堆空间不足。

我在这里要做什么?

我的服务器有 4GB RAM、4CPU,运行 ubuntu 12.04 LTS 64 位

我是 Tomcat 的新手,因此非常感谢您的帮助。

我想在生产中使用 tomcat,以下是我所做的更改:

网页文件

<servlet>
    <servlet-name>jsp</servlet-name>
    <servlet-class>org.apache.jasper.servlet.JspServlet</servlet-class>
    <init-param>
        <param-name>fork</param-name>
        <param-value>false</param-value>
    </init-param>
    <init-param>
        <param-name>xpoweredBy</param-name>
        <param-value>false</param-value>
    </init-param>
    <init-param>
        <param-name>development</param-name>
        <param-value>false</param-value>
    </init-param>
    <init-param>
        <param-name>reloading</param-name>
        <param-value>false</param-value>
    </init-param>
    <init-param>
        <param-name>genStringAsCharArray</param-name>
        <param-value>true</param-value>
    </init-param>
    <init-param>
        <param-name>modificationTestInterval</param-name>
        <param-value>40</param-value>
    </init-param>
    <init-param>
        <param-name>trimSpaces</param-name>
        <param-value>true</param-value>
    </init-param>       
    <load-on-startup>3</load-on-startup>
</servlet>

服务器.xml

<Connector port="8080" 
            protocol="org.apache.coyote.http11.Http11AprProtocol" 
            connectionTimeout="3000"
            redirectPort="8443"                 
            URIEncoding="UTF-8"
            maxPostSize="0"
            maxThreads="100"            
            enableLookups="false"
            disableUploadTimeout="false"
            maxKeepAliveRequests="-1"
            useBodyEncodingForURI="true"
            compression="on"
            compressableMimeType="text/html,text/xml,text/javascript,text/css,text/plain" 
            />

设置环境变量

export LD_LIBRARY_PATH='$LD_LIBRARY_PATH:/usr/local/apr/lib'

CATALINA_OPTS="
-server 
-Xss1G 
-Xms2G 
-Xmx2G 
-XX:+UseConcMarkSweepGC 
-XX:NewSize=1G 
-XX:+UseParNewGC

-Djava.awt.headless=true 
-Dfile.encoding=UTF-8
-XX:MaxNewSize=1G
-XX:PermSize=1G 
-XX:MaxPermSize=1G
-XX:+DisableExplicitGC


-XX:SurvivorRatio=128 
-XX:MaxTenuringThreshold=0 
-XX:+UseTLAB 
-XX:+CMSClassUnloadingEnabled 
-XX:+CMSIncrementalMode 
-XX:-UseGCOverheadLimit 
-XX:+ExplicitGCInvokesConcurrent 

-Dorg.apache.jasper.runtime.JspFactoryImpl.USE_POOL=true 
-Dcom.sun.management.jmxremote 
-Dcom.sun.management.jmxremote.port=8999 
-Dcom.sun.management.jmxremote.ssl=false 
-Dcom.sun.management.jmxremote.authenticate=true 
-Djava.rmi.server.hostname=localhost
-Dcom.sun.management.jmxremote.password.file=/home/grails/apache-tomcat/conf/jmxremote.password 
-Dcom.sun.management.jmxremote.access.file=/home/grails/apache-tomcat/conf/jmxremote.access";
export CATALINA_OPTS;

答案1

当应用程序崩溃时生成堆转储,并通过以下工具运行它:Eclipse 的内存分析工具 (MAT)。我相信您也可以从 JConsole 生成堆转储。

您可以使用以下工具生成堆转储jmap,但请查阅 JRE 的文档以了解确切的标志。生成 heapdump.bin 文件(可以是您选择的任何名称)的示例用法如下:

jmap -dump:format=b,file=/path/to/heapdump.bin <pid>

pid是运行您的应用程序的 Java 进程的进程 ID。

在 MAT 中打开此文件,查看应用程序的内存使用情况。

另外,开始查看垃圾收集日志。要启用这些日志,请参阅此处的“GC 日志选项”:http://blog.ragozin.info/2011/09/hotspot-jvm-garbage-collection-options.html

嗨嗨。

相关内容