【发布时间】:2013-09-30 17:19:32
【问题描述】:
在tomcat中,如果一个webapp确实停止了一个none daemon线程,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 中找出谁创建了线程。
谢谢!
【问题讨论】:
-
最简单的方法是单独启动每个 webapp 并检查线程。
-
谢谢,在测试环境下是个好方法,但是在线下怎么做呢?
-
这个问题的更多讨论:stackoverflow.com/questions/11722749/…
标签: java multithreading tomcat