- 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
您可能关注的文档
- 6年级数学分数乘法.ppt
- 6年级数学下册比例尺的认识课件人教新课标版.ppt
- 6年级数学分数乘整数.ppt
- 6年级数学分数连乘的计算1.ppt
- 6年级数学总复习数的认识00.ppt
- 6年级数学折扣练习PPT课件.ppt
- 6年级数学基础训练.ppt
- 6年级数学知识结构图.ppt
- 6年级数学上册确定位置13.9.ppt
- 6年级数学计算能力练习.ppt
- GB/T 18282.1-2025医疗保健产品灭菌 化学指示物 第1部分:通则.pdf
- 《GB/T 18282.1-2025医疗保健产品灭菌 化学指示物 第1部分:通则》.pdf
- 市交通运输局局长2025年专题生活会对照“四个带头”含落实意识形态工作责任制方面个人对照检查发言提纲与乡镇(街道)围绕“四个带头”主题领导班子检视问题整改方案【2篇文】.docx
- 2025年市红十字会党支部书记、团市委党支部书记组织生活会“四个带头”个人对照检查发言材料【含意识形态工作责任制落实方面】2篇文.docx
- 市水利局党支部书记2025年组织生活会对照“四个带头”个人发言材料(含意识形态工作责任制落实方面)与市委领导班子围绕“四个带头”生活会查摆问题整改方案2篇文.docx
- 检察院领导班子2025年专题生活会对照“四个带头”检查材料与市民族宗教事务局党组书记、局长围绕“四个带头”生活会对照检查材料【含反面典型案例剖析】2篇文.docx
- 对照“四个带头”重点方面含反面典型案例查摆的问题解析生活会个人对照检查发言稿与市交通运输局局长“四个带头”含落实意识形态工作责任制方面个人对照检查发言提纲【2篇文】.docx
- 市水利局党支部书记2025年组织生活会对照“四个带头”个人发言材料(含意识形态工作责任制落实方面)与纪检委员“四个带头”方面个人对照检查材料【2篇文】.docx
- 2025年市中级人民法院领导班子、市投资促进局党支部书记对照“四个带头”方面生活会检视剖析材料(含典型案例剖析、意识形态)2篇文.docx
- 医院党委领导班子2025年检视问题整改落实方案与对照“四个带头”方面含反面典型案例查摆的问题解析生活会个人对照检查发言稿【2篇文】.docx
文档评论(0)