监听 Tomcat 的启动、停止事件
当Servlet
容器启动或终止 Web 应用时,会触发ServletContextEvent
事件,该事件由ServletContextListener
来处理。在Servlet API
中有一个ServletContextListener
接口,接口中定义了处理ServletContextEvent
事件的两个方法,它能够监听ServletContext
对象的生命周期,实际上就是监听 Web 应用的生命周期。我们可以通过实现这两个方法,来实现在Tomcat
启动和停止时执行一定的操作。
监听器类编写
新建一个监听器类TomcatListener
并实现ServletContextListener
接口
1 | public class DemoListener implements ServletContextListener { |
配置 web.xml
在web.xml
中添加listener
条目
1 | <listener> |
验证
将 WAR 包部署到Tomcat
并启动,检查catalina.out
在Tomcat
启动时看到如下日志:
1 | 15-Aug-2018 15:58:44.632 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployWAR Deploying web application archive [/usr/local/Cellar/tomcat@8/8.5.28/libexec/webapps/tomcatlistener.war] |
在Tomcat
停止时看到如下日志:
1 | 15-Aug-2018 16:02:22.582 INFO [main] org.apache.catalina.core.StandardService.stopInternal Stopping service [Catalina] |
输出内容与TomcatListener
所写内容一致,Q.E.D.