执行tomcat的shutdown后用ps命令查看,tomcat的进程依然在运行,最简单粗暴的方法就是用kill -9 pid杀死进程。
导致tomcat进程无法关闭的原因可能是容器中存在非守护线程没有结束。
可以用jdk命令:jstack pid查看已启动的线程,线程描述中没有daemon的为非守护线程。
我遇到的是quartz定时任务线程有问题。用jstack查看,结果里有两组重复的quartzScheduler线程,tomcat关闭后貌似只销毁了其中一组。
为什么会出现两组相同的定时任务线程,原因是tomcat在配置host时新加了一个context,并且context的path设置的是"",并且docBase路径为appBase的子目录。这样tomcat在启动时会加载两个应用。解决方案就是context的docBase改为其他路径(不要是appBase或appBase的子目录)。