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 からスレッドを作成した人を見つける方法です。
ありがとう!