我在生产中关闭Grails应用程序时遇到问题。
从IntelliJ运行时它会干净地关闭。但是在一个独立的Tomcat 7上,关闭会让它进入一个僵尸状态,其中java进程仍然存在,但HTTP请求挂起。我必须杀死java进程(使用kill)。
我正在使用Tomcat的标准bin / startup.sh和shutdown.sh。在Tomcat停止后,我将.war放入Tomcat的/ webapps目录,然后启动。
我怀疑它可能是Quartz作业调度程序插件,但是我在grails-app / jobs中部署了一个没有作业的版本,它仍然挂起。
之前有人碰过这个吗?谢谢!
答案 0 :(得分:9)
可能一个或多个非守护程序线程仍在运行,并阻止tomcat成功关闭。
ps -ef| grep java
并找到您的Tomcat7 p_id kill -3 p_id
tail -200 logs/catalina.out
kill -3
答案 1 :(得分:3)
我同意KeremBaydoğan。可能有一个非守护程序线程不想停止。线程转储是一种很好的方法来跟踪它。
我建议使用VisualVM连接到远程JVM。这对我来说是一个非常宝贵的工具,可以收集有关我正在运行的应用程序的信息。如果您使用的是Mac,它已经作为操作系统的一部分安装。从终端输入'jvisualvm'。如果不是在Mac上,则可以从http://visualvm.java.net/
免费下载安装后,您可能需要添加一些JVM args以允许远程连接。 http://visualvm.java.net/jmx_connections.html
截图: