31logger组件tomcat日志框架及实战_第1页
31logger组件tomcat日志框架及实战_第2页
31logger组件tomcat日志框架及实战_第3页
31logger组件tomcat日志框架及实战_第4页
31logger组件tomcat日志框架及实战_第5页
已阅读5页,还剩18页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

下载下载 31|Logger组件:Tomcat2019-07-20深入拆解Tomcat& 进入课07:29每一个系统都有一些通用的模块,比如日志模块、异常处理模块、工具类等,对于Tomcat来说,比较重要的通用模块有日志、Session管理和集群管理。从今天开始我会分三期来介日志模块作为一个通用的功能,在系统里通常会使用第三方的日志框架。Java的日志框架有很多,比如:JUL(JavaUtilLogging)、Log4j、Logback、Log4j2、Tinylog此之外,还有JCL(ApacheCommonsLogging)和SLF4J这样的“门面日志”。下面是SLF4J与日志框架Logback、Log4j的关系图:07:29下载 31|Logger组件:Tomcat2019-07-20李号双深入拆解Tomcat& 进入课每一个系统都有一些通用的模块,比如日志模块、异常处理模块、工具类等,对于Tomcat来说,比较重要的通用模块有日志、Session管理和集群管理。从今天开始我会分三期来介日志模块作为一个通用的功能,在系统里通常会使用第三方的日志框架。Java的日志框架有很多,比如:JUL(JavaUtilLogging)、Log4j、Logback、Log4j2、Tinylog等。除此之外,还有JCL(ApacheCommonsLogging)和SLF4J这样的“门面日志”。下面是SLF4J与日志框架Logback、Log4j的关系图:我先来解释一下什么是“门面日志”。“门面日志”利用了设计模式中的门面模式思想,对外提供一套通用的日志记录的API,而不提供具体的日志输出服务,如果要实现日志输出,需要集成其他的日志框架,比如Log4j、Logback、Log4j2等。这种门面模式的好处在于,记录日志的API和日志输出的服务分离开,代码里面只需要关注记录日志的API,通过SLF4J指定的接口记录日志;而日志输出通过引入JAR包的方式改变引入日志输出框架JAR包。今天我们就来看看Tomcat的日志模块是如何实现的。默认情况下,Tomcat使用自身的JULI作为Tomcat内部的日志处理系统。JULI的日志门面采用了JCL;而JULI的具体实现是构建在Java原生的日志系统java.util.logging之上的,所以在看JULI的日志系统之前,我先简单介绍一下Java的日志系统。JavaJavajava.util.logging路径下,包含了几个比较重要的组件,我们通过一外提供一套通用的日志记录的API,而不提供具体的日志输出服务,如果要实现日志输出,需要集成其他的日志框架,比如Log4j、Logback、Log4j2等。这种门面模式的好处在于,记录日志的API和日志输出的服务分离开,代码里面只需要关注记录日志的API,通过SLF4J指定的接口记录日志;而日志输出通过引入JAR包的方式改变引入日志输出框架JAR包。今天我们就来看看Tomcat的日志模块是如何实现的。默认情况下,Tomcat使用自身的JULI作为Tomcat内部的日志处理系统。JULI的日志门面采用了JCL;而JULI的具体实现是构建在Java原生的日志系统java.util.logging之上的,所以在看JULI的日志系统之前,我先简单介绍一下Java的日志系统。JavaJava的日志包在java.util.logging路径下,包含了几个比较重要的组件,我们通过一 规定了日志的输出方式,如控制台输出、写入文件。Level:定 复制代码publicstaticvoidmain(String[]args)Loggerlogger=Handlerhd=new("start9复制代码publicstaticvoidmain(String[]args)Loggerlogger=Handlerhd=new("start9JULI对日志的处理方式与Java自带的基本一致,但是Tomcat中可以包含多个应用,而每个应用的日志系统应该相互独立。Java的原生日志系统是每个JVM有一份日志的配置文件,这不符合Tomcat多应用的场景,所以JULI重新实现了一些日志接口。Log的基础实现类是DirectJDKLog,这个类相对简单,就包装了一下Java的LoggerLog使用了工厂模式来向外提供实例,LogFactory是一个单例,可以通过SeviceLoader为Log提供自定义的实现版本,如果没有配置,就默认使用DirectJDKLog。复制代码privateLogFactory()2//通过ServiceLoader尝试加载Log3ServiceLoader<Log>logLoader=4Constructor<?extendsLog>56for(Loglog:logLoader)7Class<?extendsLog>8try9}catch(NoSuchMethodException|SecurityExceptione)thrownew}}//如何没有定义Log的实现类,discoveredLogConstructor为discoveredLogConstructor=}下面的代码是LogFactory的getInstance方法:复制代码publicLoggetInstance(Stringname)throwsLogConfigurationException//如果discoveredLogConstructor为null,也就没有定义Log类,默认用JULIJavaTomcat个应用的日志系统应该相互独立。Java的原生日志系统是每个JVM有一份日志的配置文件,这不符合Tomcat多应用的场景,所以JULI重新实现了一些日志接口。LogDirectJDKLog,Java复制代码privateLogFactory()//通过ServiceLoader尝试加载LogServiceLoader<Log>logLoader=Constructor<?extendsLog>5for(Loglog:logLoader)Class<?extendsLog>try catch(NoSuchMethodException|SecurityExceptione)thrownew //如何没有定义Log的实现类,discoveredLogConstructor为discoveredLogConstructor=19下面的代码是LogFactory的getInstance复制代码1publicLoggetInstance(Stringname)throwsLogConfigurationException3if(discoveredLogConstructor==null)4return5}67try8return9}catch(ReflectiveOperationException|IllegalArgumentExceptione)thrownew}}在JULI中就自定义了两个Handler:FileHandler和AsyncFileHandler。FileHandler可以简单地理解为一个在特定位置写文件的工具类,有一些写操作常用的方法,如open、write(publish)、close、flush等,使用了读写锁。其中的日志信息通过Formatter来格式AsyncFileHandler继承自FileHandler,实现了异步的写操作。其中缓存存储是通过阻塞双端队列LinkedBlockingDeque来实现的。当应用要通过这个Handler来记录一条消息消息会通过父类的publish方法写入相应文件内。这样就可以在大量日志需要写入的时候弃一些日志:复制代码1OVERFLOW_DROP_LAST2OVERFLOW_DROP_FIRSH3OVERFLOW_DROP_FLUSH4OVERFLOW_DROP_CURRENTFormatter通过一个format方法将日志记录LogRecord转化成格式化的字符串,JULI提供了三个新的Formatter。 //如果discoveredLogConstructor为null,也就没有定义Log类,默认用OnlineFormatter:基本与Java自带的SimpleFormatter格式相同,不过把所有内容Tomcat的日志配置文件为Tomcat文件夹下conf/perties。我来拆解一下这个配置文件,首先可以看到各种Handler的配置:复制代码1handlers=1.apache.juli.AsyncFileHandler,23.handlers=1.apache.juli.AsyncFileHandler,以1.apache.juli.AsyncFileHandle为例,数字是为了区分同一个类的不同实例;catalina、localhost、manager和host-manager是Tomcat用来区分不同系统日志的标志;后面的字符串表示了Handler具体类型,如果要添加Tomcat器的自定义Handler,需要在字符串里添加。接下来是每个Handler设置日志等级、目录和文件前缀,自定义的Handler也要在这里配复制代码1.apache.juli.AsyncFileHandler.level=1.apache.juli.AsyncFileHandler.directory=1.apache.juli.AsyncFileHandler.prefix=1.apache.juli.AsyncFileHandler.maxDays=1.apache.juli.AsyncFileHandler.encoding=UTF-Tomcat+SLF4J+在今天文章开头我提到,SLF4J和JCL都是日志门面,那它们有什么区别呢?它们的区别主要体现在日志服务类的绑定机制上。JCL采用运行时动态绑定的机制,在运行时动态寻找if(discoveredLogConstructor==null)return 6tryreturn}catch(ReflectiveOperationException|IllegalArgumentExceptione)thrownew 12在JULI中就自定义了两个Handler:FileHandler和AsyncFileHandler。FileHandler可以简单地理解为一个在特定位置写文件的工具类,有一些写操作常用的方法,如open、write(publish)、close、flush等,使用了读写锁。其中的日志信息通过Formatter来格式AsyncFileHandler继承自FileHandler,实现了异步的写操作。其中缓存存储是通过阻塞双端队列LinkedBlockingDeque来实现的。当应用要通过这个Handler来记录一条消息消息会通过父类的publish方法写入相应文件内。这样就可以在大量日志需要写入的时候复制代码FormatterformatLogRecord,JULI供了三个新的Formatter。SLF4J日志输出服务绑定则相对简单很多,在编译时就静态绑定日志框架,只需要提前引入需要的日志框架。另外Logback可以说Log4j的进化版,在性能和可用性方面都有所提升。你可以参考官网上这篇文章来了解Logback的优势。基于此我们来实战一下如何将Tomcat默认的日志框架切换成为“SLF4J+Logback”。根据你的Tomcat版本,从这里下载所需要文件。解压后你会看到一个类似于Tomcat替换或拷贝下列这些文件到Tomcat的安装目录:删除启动今天我们谈了日志框架与日志门面的区别,以及Tomcat的日志模块是如何实现的。默认情况下,Tomcat的日志模板叫作JULI,JULI的日志门面采用了JCL,而具体实现是基于Java默认的日志框架JavaUtilLogging,Tomcat在JavaUtilLogging基础上进行了改造,使得它自身的日志框架不会影响Web式。最后我分享了如何将Tomcat的日志模块切换到时下流行的“SLF4J+Logback”,希望对你有所帮助。OnlineFormatterJavaSimpleFormatterTomcatTomcatconf/perties。我来拆解一下这个配置文件,首先可以看到各种Handler的配置:复制代码1handlers=1.apache.juli.AsyncFileHandler,23.handlers=1.apache.juli.AsyncFileHandler,以1.apache.juli.AsyncFileHandler为例,数字是为了区分同一个类的不同实例;catalina、localhost、manager和host-manager是Tomcat用来区分不同系统日志的标志;后面的字符串表示了Handler具体类型,如果要添加Tomcat服务器的自定义Handler,需要在字符串里添加。接下来是每个Handler设置日志等级、目录和文件前缀,自定义的Handler也要在这里配复制代码1.apache.juli.AsyncFileHandler.level=1.apache.juli.AsyncFileHandler.directory=1.apache.juli.AsyncFileHandler.prefix=1.apache.juli.AsyncFileHandler.maxDays=1.apache.juli.AsyncFileHandler.encoding=UTF-Tomcat+SLF4J+在今天文章开头我提到,SLF4J和JCLTomcat独立部署时,各种日志都输出到了相应的日志文件,假如SpringBoot以内嵌式的方式运行Tomcat,这种情况下To

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论