监听Tomcat的启动、停止事件

Servlet容器启动或终止Web应用时,会触发ServletContextEvent事件,该事件由ServletContextListener来处理。在Servlet API中有一个ServletContextListener接口,接口中定义了处理ServletContextEvent事件的两个方法,它能够监听ServletContext对象的生命周期,实际上就是监听Web应用的生命周期。我们可以通过实现这两个方法,来实现在Tomcat启动和停止时执行一定的操作。

监听器类编写

新建一个监听器类TomcatListener并实现ServletContextListener接口

1
2
3
4
5
6
7
8
9
10
11
public class DemoListener implements ServletContextListener {
@Override
public void contextInitialized(ServletContextEvent servletContextEvent) {
System.out.println("Tomcat Started");
}

@Override
public void contextDestroyed(ServletContextEvent servletContextEvent) {
System.out.println("Tomcat Destroyed");
}
}

配置web.xml

web.xml中添加listener条目

1
2
3
<listener>
<listener-class>com.project.name.listener.DemoListener</listener-class>
</listener>

验证

将WAR包部署到Tomcat并启动,检查catalina.out

Tomcat启动时看到如下日志:

1
2
15-Aug-2018 15:58:44.632 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployWAR Deploying web application archive [/usr/local/Cellar/[email protected]/8.5.28/libexec/webapps/tomcatlistener.war]
Tomcat Started

Tomcat停止时看到如下日志:

1
2
15-Aug-2018 16:02:22.582 INFO [main] org.apache.catalina.core.StandardService.stopInternal Stopping service [Catalina]
Tomcat Destroyed

输出内容与TomcatListener所写内容一致,Q.E.D.