有些时候我们需要在TOMCAT关闭的时候做一些收尾的工作,比如保存未完成的任务队列到文本或数据库等,或者在JVM退出之前做一些
收尾的事情,这个时候就可以注册JVM的HOOK,它会在JVM的最后一个非后台线程退出的时候执行。
package example;
import java.util.concurrent.TimeUnit;
import java.util.logging.Logger;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
public class RuntimeListener implements ServletContextListener {
private static final Logger log = Logger.getLogger(RuntimeListener.class
.getName());
public void contextInitialized(ServletContextEvent arg0) {
log.info("contextInitialized");
/*
* 注册JVM钩子,在JVM关闭之前做一些收尾的工作,当然也能阻止TOMCAT的关闭;必须放在contextInitialized中注册。
*/
Runtime.getRuntime().addShutdownHook(new Thread(new Runnable() {
public void run() {
int n = 0;
while (n < 10) {
log.info(Thread.currentThread() + "," + n++);
try {
TimeUnit.SECONDS.sleep(1);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}));
}
public void contextDestroyed(ServletContextEvent arg0) {
log.info("contextDestroyed ....");
}
}