网站大量收购闲置独家精品文档,联系QQ:2885784924

6生命周期管理和日志记录器.ppt

  1. 1、本文档共22页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 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)

wuyoujun92 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档