在 tomcat 中,如果一个 webapp 确实停止了一个无守护线程,tomcat 不能被 shutdown.sh 关闭
例如:
public class demo implements ServletContextListener{
public void contextDestroyed(ServletContextEvent arg0) {
// TODO Auto-generated method stub
// yes,we can cancel timer in here,but this is not the major problem
}
public void contextInitialized(ServletContextEvent arg0) {
Timer timer = new Timer();
timer.schedule(new Test(), 1000, 1000*10);
}
}
public class Test extends TimerTask{
@Override
public void run() {
System.out.println("AAAA");
}
}
像上面一样,tomcat不能被shutdown.sh关闭。来自 jvisualvm,线程检查员说:
"Timer-0" - Thread t@40
java.lang.Thread.State: TIMED_WAITING
at java.lang.Object.wait(Native Method)
- waiting on <3957edeb> (a java.util.TaskQueue)
at java.util.TimerThread.mainLoop(Timer.java:552)
at java.util.TimerThread.run(Timer.java:505)
Locked ownable synchronizers:
- None
堆栈信息没有指出哪个 java 类创建了线程,我的问题是如何从许多 webapps 中找出谁创建了线程。
谢谢!