- 1、本文档共22页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
6生命周期管理和日志记录器
生命周期管理与日志记录器;Lifecycle;生命周期组件;Catalina通过Lifecycle接口达到统一启动/关闭组件的效果。
Lifecycle组件通过实现start()和stop()方法来供父组件调用
Lifecycle通过注册多个事件监听器赖对放生在该组件上的事件进行监听。事件监听器类需要实现LifecycleListener接口。
LifecycleListener接口实现监听事件方法,需要传入事件类LifecycleEvent
Catalina提供了一个工具类LifecycleSupport 帮助组件管理监听器,并触发响应的生命周期事件。
;组件通过实现org.apache.catalina.Lifecycle接口,可以达到统一启动/关闭这些组件的效果。
组件可以触发的事件如下:
BEFORE_START_EVENT
START_EVENT
AFTER_START_EVENT
BEFORE_STOP_EVENT
STOP_EVENT
AFTER_STOP_EVENT;addLifecycleListener
添加监听器事件
findLifecycleListener
查找监听器事件
removeLifecycleListener
移除监听器事件
Start
启动操作实现方法
Stop
关闭操作实现方法;LifecycSupport – 工具类;Lifecycle管理生命周期的应用程序;Lifecycle管理生命周期的应用程序;SimpleContext – start(); //启动所有字容器
Container children[] = findChildren();
for(int i = 0; i children.length; i++){
if(children[i] instanceof Lifecycle)
((Lifecycle) children[i].start();
}
//启动管道以及阀
if( pipline instanceof Lifecycle)
((Lifecycle) pipline).start();
//执行所有的启动事件
lifecycle.fireLifecycleEvent(START_EVENT, null);
}catch(Exception e){
e.printStackTrack();
}
//执行所有的启动后置事件
lifecycle.fireLifecycleEvent(AFTER_START_EVENT, null);
}
;观察p103页应用运行结果
理解控制台的输出顺序
自定义Wrapper应用LifecycleListener事件,重新测试应用程序,观察输出; 日志记录器;Tomcat提供3种日志记录器,均继承自实现了org.apache.catalina.Logger接口的LoggerBase类
SystemOutLogger
提供log重载实现将接受到的每条日志消息传递给System.out.println()方法
SystemErrLogger
提供log重载实现将接受到的每条日志消息传递给System.err.println()方法
FileLogger
将servlet容器中接受的消息写入到文件中,并选择是否为每条消息添加时间戳;Tomcat日志记录器;LoggerBase是Tomcat对org.apache.catalina.logger接口的基本实现。
Tomcat4中LoggerBase是抽象类,实现了除log(Strng msg)方法外的全部方法实现。
Tomcat4中LoggerBase下日志等级默认设置为ERROR
Tomcat4中LoggerBase重载实现了传入日志等级比指定级别的verbosity变量低的时候才记录日志消息。;FileLogger将从servlet容器中接受的日志消息写到一个文件中,并且可以选择是否要为每条消息添加时间戳。
FileLogger首次实例化的时候,会创建一个包含当日日期信息的日志文件。
日志写入的时候,如果日期发生变化,则创建一个新的文件。
FileLogger实现了Lifecycle接口,由相关联的servlet容器负责启动/关闭。
;public void log(String msg){
//构造需要的时间搓,默认格式 yyyy-mm-dd hh:mm:ss .fffffffff
Timestamp ts = new Timestamp(System.currentTimeMillis());
String tsString = ts.toString().substring(0 , 19);
String tsD
文档评论(0)