在没有遇到Permgen异常的情况下从Ant重新加载Tomcat应用程序的正确方法是什么?

Tim*_*her 6 ant tomcat

我和我的团队正在开发一个Java Web应用程序,使用Tomcat作为我们的开发测试服务器,Ant作为我们的构建工具.我们的平台是Windows,但我们正在运行Cygwin中的Tomcat,因为我们首选的shell是bash.由于频繁重启应用程序以使新实现的功能可用于测试,我们遇到了内存耗尽的一致问题.

我们最初尝试重新加载应用程序,而无需使用提供的Catalina ant任务重新启动服务器.这适用于几次迭代但是我们总是耗尽Permgen空间.需要说明的是,这是指与Tomcat捆绑在一起的Ant任务,它启动,停止,部署,取消部署和列出应用程序.再次,这样做超过3次会导致Permgen内存错误,我们不得不手动杀死java进程.这就是为什么我们试图杀死服务器本身而不是应用程序.

我们的下一个想法是每次都重启服务器.我们一直存在的问题是服务器的关闭似乎并没有破坏java进程.最终,除非您手动监视并终止它们,否则内存只会耗尽所有这些僵尸进程.我尝试过的实现如下:

  1. 直接执行bootstrap jar.

    <target name="tomcat.server.start" depends="tomcat.server.online" unless="tomcat.server.online">
        <java jar="${tomcat.home}/bin/bootstrap.jar" fork="true">
            <jvmarg value="-Dcatalina.home=${tomcat.home}" />
        </java>
        <waitfor maxwait="30" maxwaitunit="second" timeerty="tomcat.offline">
            <socket port="8081" server="127.0.0.1" />
        </waitfor>
        <fail if="tomcat.offline">Tomcat failed to come up.</fail>
    </target>
    
    Run Code Online (Sandbox Code Playgroud)
  2. 直接执行shutdown | startup.bat文件

    <target name="tomcat.server.start" depends="tomcat.server.online" unless="tomcat.server.online">
        <exec executable="bash" os="Windows" failonerror="true" >
            <arg line="-i ../tools/tomcat/bin/startup.bat />
        </exec>
        <waitfor maxwait="30" maxwaitunit="second" timeerty="tomcat.offline">
            <socket port="8081" server="127.0.0.1" />
        </waitfor>
        <fail if="tomcat.offline">Tomcat failed to come up.</fail>
    </target>
    
    Run Code Online (Sandbox Code Playgroud)
  3. 执行shutdown | startup.sh文件.

    <target name="tomcat.server.start" depends="tomcat.server.online" unless="tomcat.server.online">
        <exec executable="bash" failonerror="true" >
            <arg line="-i ../tools/tomcat/bin/startup.sh" />
        </exec>
        <waitfor maxwait="30" maxwaitunit="second" timeerty="tomcat.offline">
            <socket port="8081" server="127.0.0.1" />
        </waitfor>
        <fail if="tomcat.offline">Tomcat failed to come up.</fail>
    </target>
    
    Run Code Online (Sandbox Code Playgroud)

所有上述方法都使java进程保持活动状态,至少在我实现它们时是这样.

在这一点上,我不知道该怎么做.我听说过在你没有重装容器或应用程序的情况下进行爆炸式开发,但我从未发现如何做到这一点.我不知道这里接受的最佳做法是什么.

我的问题基本上是在进行测试时运行Permgen空间.如果我首先提出错误的问题,那么请随意更正标题.我对任何建议都持开放态度.

谢谢!

ste*_*own 4

使用Tomcat Ant 任务。大多数 Tomcat 发行版中都包含 Catalina-ant.jar。一般来说,最好将其与try-catch Ant任务结合起来。

<taskdef name="start" classname="org.apache.catalina.ant.StartTask" />
<taskdef name="stop" classname="org.apache.catalina.ant.StopTask" />
<taskdef name="try" classname="ise.antelope.tasks.TryTask"/>
<try>
    <stop url="${url}"
        username="${username}"
        password="${password}"
        path="${path}"/>
    <catch>
        <echo>${path} stop failed.</echo>
    </catch>
</try>
 <try>
    <start url="${url}"
        username="${username}"
        password="${password}"
        path="${path}"/>
    <catch>
        <echo>${path} start failed.</echo>
    </catch>
</try>
Run Code Online (Sandbox Code Playgroud)

如果这是一个纯粹的内存问题,您可能需要在 JVM 启动时调整一些内存条目(我经常这样做,但从未像这样清楚地写过它

-XX:+UseConcMarkSweepGC
-XX:+CMSPermGenSweepingEnabled
-XX:+CMSClassUnloadingEnabled
-XX:MaxPermSize=256m
Run Code Online (Sandbox Code Playgroud)