Logback使用及配置标签详解

Posted 朗妹儿

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Logback使用及配置标签详解相关的知识,希望对你有一定的参考价值。


  • 一、logback的介绍

  • 二、logback取代log4j的理由

  • 三、logback配置的步骤

    • 1、Maven引入相关包

    • 2、在resources目录中创建logback-test.xml配置文件

  • 四、logback节点配置详解

    • 1、根节点 ``

    • 2、`` 的子节点

      • 2.1.1、ConsoleAppender

      • 2.1.2、FileAppender [不常用]

      • 2.1.3、RollingFileAppender [常用]

      • 2.1.3.1、TimeBaseRollingPolicy :最常用的滚动策略,根据时间来制定滚动策略,即负责滚动也负责触发滚动。有如下节点:

      • 2.1.3.2、 SizeBasedTriggeringPolicy : 查看当前活动文件的大小

      • 2.1、 的子节点,是负责写日志的组件。

      • 2.2、logger 节点

      • 2.3、root 节点

    • 3、`` 过滤节点

      • 3.1 : 级别过滤器(LevelFilter)

      • 3.2 : 临界值过滤器(ThresholdFilter)

      • 3.3 : 求值过滤器(EvaluatorFilter)

      • 3.4 : 匹配器(Matchers)

一、logback的介绍

Logback是由log4j创始人Ceki Gülcü设计的另一个开源日志组件,官方网站:   http://logback.qos.ch 它当前分为下面几个模块:
  • logback-core其它两个模块的基础模块

  • logback-classic它是log4j的一个改良版本,同时它完整实现了slf4j API使你可以很方便地更换成其它日志系统如log4j或JDK14 Logging

  • logback-access访问模块与Servlet容器集成提供通过Http来访问日志的功能

既然做为日志组件,日志级别肯定也是有的,而且和log4j一样。 日志级别从低到高分为 TRACE < DEBUG < INFO < WARN < ERROR < FATAL ,如果设置为WARN,则低于WARN的信息都不会输出

二、logback取代log4j的理由

创始人Ceki Gülcü都说log4j写的很烂...实在不想改里面的代码了...干脆重来了一个logback...那还有什么理由不换呢? 而且SpringBoot默认支持logback

三、logback配置的步骤

自定义配置logback,需要按照约定创建名字为logback-test.xml或者logback.xml的配置文件 在SpringBoot中,使用默认约定名字logbac-spring.xml来定义配置文件名字

1、Maven引入相关包

 
   
   
 
  • <dependency>

  • <groupId>ch.qos.logback</groupId>

  • <artifactId>logback-core</artifactId>

  • <version>1.2.3</version>

  • </dependency>


  • <dependency>

  • <groupId>ch.qos.logback</groupId>

  • <artifactId>logback-classic</artifactId>

  • <version>1.2.3</version>

  • <scope>test</scope>

  • </dependency>


  • <dependency>

  • <groupId>org.slf4j</groupId>

  • <artifactId>slf4j-api</artifactId>

  • <version>1.7.25</version>

  • </dependency>

如果你是SpringBoot工程的话,不需要自己引入了,SpringBoot工程已经帮你配置好了

2、在resources目录中创建logback-test.xml配置文件

如果是SpringBoot工程,请创建logback-spring.xml文件
下面是配置好的完整的logback-test.xml文件代码
 
   
   
 
  • <?xml version="1.0" encoding="UTF-8"?>

  • <!-- 日志级别从低到高分为TRACE < DEBUG < INFO < WARN < ERROR < FATAL,如果设置为WARN,则低于WARN的信息都不会输出 -->

  • <!-- scan:当此属性设置为true时,配置文件如果发生改变,将会被重新加载,默认值为true -->

  • <!-- scanPeriod:设置监测配置文件是否有修改的时间间隔,如果没有给出时间单位,默认单位是毫秒。当scan为true时,此属性生效。默认的时间间隔为1分钟。-->

  • <!-- debug:当此属性设置为true时,将打印出logback内部日志信息,实时查看logback运行状态。默认值为false。-->

  • <configuration scan="true" scanPeriod="10 seconds">


  • <contextName>logback</contextName>

  • <property name="log.path" value="c:/yingside/log" />


  • <!-- 彩色日志 -->

  • <!-- 彩色日志依赖的渲染类 -->

  • <conversionRule conversionWord="clr" converterClass="org.springframework.boot.logging.logback.ColorConverter" />

  • <conversionRule conversionWord="wex" converterClass="org.springframework.boot.logging.logback.WhitespaceThrowableProxyConverter" />

  • <conversionRule conversionWord="wEx" converterClass="org.springframework.boot.logging.logback.ExtendedWhitespaceThrowableProxyConverter" />

  • <!-- 彩色日志格式 -->

  • <property name="CONSOLE_LOG_PATTERN" value="${CONSOLE_LOG_PATTERN:-%clr(%d{yyyy-MM-dd HH:mm:ss.SSS}){faint} %clr(${LOG_LEVEL_PATTERN:-%5p}) %clr(${PID:- }){magenta} %clr(---){faint} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}}"/>



  • <!--输出到控制台-->

  • <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">

  • <!--此日志appender是为开发使用,只配置最底级别,控制台输出的日志级别是大于或等于此级别的日志信息-->

  • <filter class="ch.qos.logback.classic.filter.ThresholdFilter">

  • <level>info</level>

  • </filter>

  • <encoder>

  • <Pattern>${CONSOLE_LOG_PATTERN}</Pattern>

  • <!-- 设置字符集 -->

  • <charset>UTF-8</charset>

  • </encoder>

  • </appender>



  • <!--输出到文件-->


  • <!-- 时间滚动输出 level为 DEBUG 日志 -->

  • <appender name="DEBUG_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">

  • <!-- 正在记录的日志文件的路径及文件名 -->

  • <file>${log.path}/log_debug.log</file>

  • <!--日志文件输出格式-->

  • <encoder>

  • <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>

  • <charset>UTF-8</charset> <!-- 设置字符集 -->

  • </encoder>

  • <!-- 日志记录器的滚动策略,按日期,按大小记录 -->

  • <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">

  • <!-- 日志归档 -->

  • <fileNamePattern>${log.path}/debug/log-debug-%d{yyyy-MM-dd}.%i.log</fileNamePattern>

  • <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">

  • <maxFileSize>100MB</maxFileSize>

  • </timeBasedFileNamingAndTriggeringPolicy>

  • <!--日志文件保留天数-->

  • <maxHistory>15</maxHistory>

  • </rollingPolicy>

  • <!-- 此日志文件只记录debug级别的 -->

  • <filter class="ch.qos.logback.classic.filter.LevelFilter">

  • <level>debug</level>

  • <onMatch>ACCEPT</onMatch>

  • <onMismatch>DENY</onMismatch>

  • </filter>

  • </appender>


  • <!-- 时间滚动输出 level为 INFO 日志 -->

  • <appender name="INFO_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">

  • <!-- 正在记录的日志文件的路径及文件名 -->

  • <file>${log.path}/log_info.log</file>

  • <!--日志文件输出格式-->

  • <encoder>

  • <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>

  • <charset>UTF-8</charset>

  • </encoder>

  • <!-- 日志记录器的滚动策略,按日期,按大小记录 -->

  • <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">

  • <!-- 每天日志归档路径以及格式 -->

  • <fileNamePattern>${log.path}/info/log-info-%d{yyyy-MM-dd}.%i.log</fileNamePattern>

  • <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">

  • <maxFileSize>100MB</maxFileSize>

  • </timeBasedFileNamingAndTriggeringPolicy>

  • <!--日志文件保留天数-->

  • <maxHistory>15</maxHistory>

  • </rollingPolicy>

  • <!-- 此日志文件只记录info级别的 -->

  • <filter class="ch.qos.logback.classic.filter.LevelFilter">

  • <level>info</level>

  • <onMatch>ACCEPT</onMatch>

  • <onMismatch>DENY</onMismatch>

  • </filter>

  • </appender>


  • <!-- 时间滚动输出 level为 WARN 日志 -->

  • <appender name="WARN_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">

  • <!-- 正在记录的日志文件的路径及文件名 -->

  • <file>${log.path}/log_warn.log</file>

  • <!--日志文件输出格式-->

  • <encoder>

  • <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>

  • <charset>UTF-8</charset> <!-- 此处设置字符集 -->

  • </encoder>

  • <!-- 日志记录器的滚动策略,按日期,按大小记录 -->

  • <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">

  • <fileNamePattern>${log.path}/warn/log-warn-%d{yyyy-MM-dd}.%i.log</fileNamePattern>

  • <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">

  • <maxFileSize>100MB</maxFileSize>

  • </timeBasedFileNamingAndTriggeringPolicy>

  • <!--日志文件保留天数-->

  • <maxHistory>15</maxHistory>

  • </rollingPolicy>

  • <!-- 此日志文件只记录warn级别的 -->

  • <filter class="ch.qos.logback.classic.filter.LevelFilter">

  • <level>warn</level>

  • <onMatch>ACCEPT</onMatch>

  • <onMismatch>DENY</onMismatch>

  • </filter>

  • </appender>



  • <!-- 时间滚动输出 level为 ERROR 日志 -->

  • <appender name="ERROR_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">

  • <!-- 正在记录的日志文件的路径及文件名 -->

  • <file>${log.path}/log_error.log</file>

  • <!--日志文件输出格式-->

  • <encoder>

  • <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>

  • <charset>UTF-8</charset> <!-- 此处设置字符集 -->

  • </encoder>

  • <!-- 日志记录器的滚动策略,按日期,按大小记录 -->

  • <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">

  • <fileNamePattern>${log.path}/error/log-error-%d{yyyy-MM-dd}.%i.log</fileNamePattern>

  • <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">

  • <maxFileSize>100MB</maxFileSize>

  • </timeBasedFileNamingAndTriggeringPolicy>

  • <!--日志文件保留天数-->

  • <maxHistory>15</maxHistory>

  • </rollingPolicy>

  • <!-- 此日志文件只记录ERROR级别的 -->

  • <filter class="ch.qos.logback.classic.filter.LevelFilter">

  • <level>ERROR</level>

  • <onMatch>ACCEPT</onMatch>

  • <onMismatch>DENY</onMismatch>

  • </filter>

  • </appender>


  • <!--

  • <logger>用来设置某一个包或者具体的某一个类的日志打印级别、

  • 以及指定<appender>。<logger>仅有一个name属性,

  • 一个可选的level和一个可选的addtivity属性。

  • name:用来指定受此logger约束的某一个包或者具体的某一个类。

  • level:用来设置打印级别,大小写无关:TRACE, DEBUG, INFO, WARN, ERROR, ALL 和 OFF,

  • 还有一个特俗值INHERITED或者同义词NULL,代表强制执行上级的级别。

  • 如果未设置此属性,那么当前logger将会继承上级的级别。

  • addtivity:是否向上级logger传递打印信息。默认是true。

  • -->

  • <!--<logger name="org.springframework.web" level="info"/>-->

  • <!--<logger name="org.springframework.scheduling.annotation.ScheduledAnnotationBeanPostProcessor" level="INFO"/>-->

  • <!--

  • 使用mybatis的时候,sql语句是debug下才会打印,而这里我们只配置了info,所以想要查看sql语句的话,有以下两种操作:

  • 第一种把<root level="info">改成<root level="DEBUG">这样就会打印sql,不过这样日志那边会出现很多其他消息

  • 第二种就是单独给dao下目录配置debug模式,代码如下,这样配置sql语句会打印,其他还是正常info级别:

  • -->

  • <!--开发环境:打印控制台-->

  • <!--myibatis 日志输出-->

  • <logger name="com.yingside.dao" level="debug"/>


  • <!--

  • root节点是必选节点,用来指定最基础的日志输出级别,只有一个level属性

  • level:用来设置打印级别,大小写无关:TRACE, DEBUG, INFO, WARN, ERROR, ALL 和 OFF,

  • 不能设置为INHERITED或者同义词NULL。默认是DEBUG

  • 可以包含零个或多个元素,标识这个appender将会添加到这个logger。

  • -->


  • <root level="info">

  • <appender-ref ref="CONSOLE" />

  • <appender-ref ref="DEBUG_FILE" />

  • <appender-ref ref="INFO_FILE" />

  • <appender-ref ref="WARN_FILE" />

  • <appender-ref ref="ERROR_FILE" />

  • </root>


  • <!--生产环境:输出到文件-->

  • <!--<springProfile name="pro">-->

  • <!--<root level="info">-->

  • <!--<appender-ref ref="CONSOLE" />-->

  • <!--<appender-ref ref="DEBUG_FILE" />-->

  • <!--<appender-ref ref="INFO_FILE" />-->

  • <!--<appender-ref ref="ERROR_FILE" />-->

  • <!--<appender-ref ref="WARN_FILE" />-->

  • <!--</root>-->

  • <!--</springProfile>-->

  • </configuration>

如果希望进一步了解logback节点的具体详情,可以继续往下看第四点,其实平时工作把上面的完整的xml配置稍微修改成你自己的内容就可以了

四、logback节点配置详解

1、根节点 <configuration></configuration>

属性 :  debug : 默认为false ,设置为true时,将打印出logback内部日志信息,实时查看logback运行状态。  scan : 配置文件如果发生改变,将会重新加载,默认值为true;  scanPeriod : 检测配置文件是否有修改的时间间隔,如果没有给出时间单位,默认单位时毫秒,当scan为true时,这个属性生效,默认时间间隔为1min。
 
   
   
 
  • <?xml version="1.0" encoding="utf-8"?>

  • <configuration debug="true" scan="true" scanPeriod="2">

  • <!--TODO : 子节点信息-->

  • </configuration>

可以这样描述配置文件的基本结构:
<configuration> 开头,后面有零个或多个 <appender> 元素,有零个或多个 <logger> 元素,有最多一个 <root> 元素
Logback使用及配置标签详解

2、<configuration> 的子节点

  1. <appender></appender>

  2. <logger></logger>

  3. <root></root>

2.1、<appender> 是 <configuration> 的子节点,是负责写日志的组件。

appender 有两个必要属性 name ,class 。

name 指定 appender 的名称, class 指定 appender 的全限定类名 class 包括 : ch.qos.logback.core.ConsoleAppender 控制台输出 ch.qos.logback.core.FileAppender 文件输出 ch.qos.logback.core.RollingFileAppender 文件滚动输出
 
   
   
 
  • <?xml version="1.0" encoding="utf-8"?>

  • <configuration debug="true" scan="true" scanPeriod="2">

  • <!-- 控制台输出日志 -->

  • <appender name ="console_out" class="ch.qos.logback.core.ConsoleAppender">

  • </appender>


  • <!-- 文件输出日志 -->

  • <appender name="file_out" class="ch.qos.logback.core.FileAppender">

  • </appender>


  • <!-- 文件滚动输出日志 -->

  • <appender name="file_out" class="ch.qos.logback.core.RollingFileAppender">

  • </appender>


  • <root></root>

  • <loger></loger>

  • </configuration>

2.1.1、ConsoleAppender
把日志添加到控制台,有如下节点:   <encoder>  : 对日志进行格式化。   <target>  : 字符串System.out 或者 System.err, 默认 System.out;
 
   
   
 
  • <?xml version="1.0" encoding="UTF-8" ?>

  • <configuration scan="true" scanPeriod="60 seconds">

  • <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">

  • <encoder>

  • <pattern>

  • %d [%thread] %-5level %logger{35} - %msg %n

  • </pattern>

  • </encoder>

  • </appender>

  • <root level="info">

  • <appender-ref ref="CONSOLE"/>

  • </root>

  • </configuration>

部分部分转义字符简单说明:  %d: 表示日期 %thread: 表示线程名 %-5level: 级别从左显示5个字符宽度 %logger: 表示当前日志对象 %msg: 日志消息%n: 是换行符
更多转移字符参考:   Logback PatternLayout
2.1.2、FileAppender [不常用]
把日志添加到文件,有如下节点:   <file>  : 被写入的文件名,可以是相对目录 , 也可以是绝对目录 , 如果目录不存在则会自动创建  <append>  : 如果是true , 日志被追加到文件结尾 , 如果是false,清空现存文件 , 默认是true  <encoder> : 对日志进行格式化  <prodent>  : 如果是true,日志会被安全的写入文件 , 即使其他的FileAppender也会向此文件做写入操作 , 默认是false
 
   
   
 
  • <?xml version="1.0" encoding="utf-8"?>

  • <configuration>

  • <!-- 控制台输出日志 -->

  • <appender name ="console_out" class="ch.qos.logback.core.ConsoleAppender">

  • <encoder>

  • <pattern>

  • %d [%thread] %-5level %logger{35} - %msg %n

  • </pattern>

  • </encoder>

  • </appender>


  • <!-- 文件输出日志 -->

  • <appender name="file_out" class="ch.qos.logback.core.FileAppender">

  • <file>d:/logs/debug.log</file>

  • <encoder>

  • <pattern>

  • %d [%thread] %-5level %logger{35} - %msg %n

  • </pattern>

  • </encoder>

  • </appender>

  • </configuration>

2.1.3、RollingFileAppender [常用]
滚动纪录文件,先将日志记录到指定文件,当符合某种条件时,将日志记录到其他文件,有如下节点:   <file>  : 被写入的文件名,可以是相对目录,也可以解决目录,如果目录不存在则自动创建。   <append>  : 如果是true,日志被追加到文件结尾,如果是false,清空现存文件,默认是true; <encoder>  : 对日志进行格式化  <rollingPolicy>  : 当发生滚动时,决定 RollingFileAppender 的行为,涉及文件移动和重命名。
2.1.3.1、TimeBaseRollingPolicy :最常用的滚动策略,根据时间来制定滚动策略,即负责滚动也负责触发滚动。有如下节点:
1) :  <fileNamePattern>  必要节点,包含文件及“%d” 转换符,“%d”可以包含一个java.text.SimpleDateFormat 制定的时间格式,如: %d{yyyy-MM},如果直接使用 %d ,默认格式是 yyyy-MM-dd。
RollingFileAppender 的file 子节点可有可无,通过设置file,可以为活动文件和归档文件制定不同位置,当前日志总是纪录到file指定的文件,活动文件的名称不会改变,如果没有设置file,活动文件的名称会根据fileNamePattern的值,每隔一段时间改变一次,“/”或者“\” 会被当作目录分隔符。
2) : <maxHistory>  可选节点,控制保留的归档文件的最大数量,超出数量就删除旧文件,假设设置每个月滚动,且  是 6,则只保存最近6个月的文件,删除之前的旧文件,注意: 删除旧文件是哪些为了归档而创建的目录也会被删除。
3) : <filenamePattern>  必须包含“%i” 例如: 设置最小值,和最大值分别为1和2,命名模式为 log%i.log,会产生归档文件log1.log和log2.log,还可以指定文件压缩选项,例如: log%i.log.gz 或者 log%i.log.zip
4) : <triggeringPolicy>  告知RollingFileAppender 激活RollingFileAppender滚动
2.1.3.2、 SizeBasedTriggeringPolicy : 查看当前活动文件的大小
如果超过指定大小会告知 RollingFileAppender , 触发当前活动滚动 , 只有一个节点 , 用来规定文件大小
<maxFileSize>  : 活动文件的大小 , 默认10MB
<prudent> 当为true时 , 不支持FixedWindowRollingPolicy , 支持TimeBasedRollingPolicy , 但是有两个限制 , 1不支持也不允许文件压缩 , 2不能设置file属性 . 必须留空
 
   
   
 
  • <!-- 错误日志的文件滚动记录 -->

  • <appender name="errorAppender" class="ch.qos.logback.core.RollingFileAppender">

  • <file>d:/logs/error.log</file>

  • <!-- 设置滚动策略 -->

  • <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">

  • <!--设置日志命名模式-->

  • <fileNamePattern>errorFile.%d{yyyy-MM-dd}.log</fileNamePattern>

  • <!--最多保留30天log-->

  • <maxHistory>30</maxHistory>

  • </rollingPolicy>

  • <!-- 超过150MB时,触发滚动策略 -->

  • <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">

  • <maxFileSize>150</maxFileSize>

  • </triggeringPolicy>

  • <encoder>

  • <pattern>%d [%thread] %-5level %logger{35} - %msg %n</pattern>

  • </encoder>

  • </appender>

2.2、logger 节点

<logger> 用来设置某一个包或者具体的某一个类的日志打印级别、以及指定 <appender>   <logger> 仅有一个name属性,一个可选的level和一个可选的addtivity属性。
name:用来指定受此logger约束的某一个包或者具体的某一个类。
level:用来设置打印级别,大小写无关: TRACE, DEBUG, INFO, WARN, ERROR, ALL 和 OFF,还有一个特俗值INHERITED或者同义词NULL,代表强制执行上级的级别。 如果未设置此属性,那么当前logger将会继承上级的级别。
addtivity:是否向上级logger传递打印信息。 默认是true。
比如: 使用mybatis的时候,sql语句是debug下才会打印,如果我们只配置了info,所以想要查看sql语句的话,有以下两种操作:
第一种 改成 这样就会打印sql,不过这样日志那边会出现很多其他消息
第二种 就是单独给dao下目录配置debug模式,代码如下,这样配置sql语句会打印,其他还是正常info级别:

  
    
    
  
  • <logger name="com.yingside.dao" level="debug">

  • <appender-ref ref = "console_out"/>

  • </logger>

上面这段话的意思是把 com.yingside.dao 包下面的所有类使用 debug 的日志级别,并且 appender 使用上面定义好的 console_out

2.3、root 节点

元素配置根 logger。 该元素有一个 level 属性。 没有 name 属性,因为已经被命名 为“root” Level 属性的值大小写无关,其值为下面其中一个字符串: TRACE、DEBUG、INFO、 WARN、ERROR、ALL 和 OFF。 注意不能设置为“INHERITED” 或“NULL”。 元素可以包含零个或多个元素。 与元素类似,声明 元素后,会先关闭然后移除全部当前 appender,只引用声明了的 appender。 如果 root 元素没 有引用任何 appender,就会失去所有 appender。

3、<filter> 过滤节点

Logback 的过滤器基于三值逻辑(ternary logic),允许把它们组装或成链,从而组成任 意的复合过滤策略。 这里的所谓三值逻辑是说,过滤器的返回值只能是 ACCEPT、DENY 和 NEUTRAL 的其中一个。 过滤器一般分为如下几类 :

3.1 : 级别过滤器(LevelFilter)

LevelFilter 根据记录级别对记录事件进行过滤。 如果事件的级别等于配置的级别,过滤 器会根据 onMatch 和 onMismatch 属性接受或拒绝事件。 下面是个配置文件例子:
 
   
   
 
  • <?xml version="1.0" encoding="utf-8"?>

  • <configuration>

  • <!-- conf consoel out -->

  • <appender name ="console_out" class="ch.qos.logback.core.ConsoleAppender">

  • <filter class="ch.qos.logback.classic.filter.LevelFilter">

  • <!-- 过滤掉非INFO级别 -->

  • <level>INFO</level>

  • <onMatch>ACCEPT</onMatch>

  • <onMismatch>DENY</onMismatch>

  • </filter>


  • <encoder>

  • <pattern>%-4relative [%thread] %-5level %logger{30} - %msg%n</pattern>

  • </encoder>

  • </appender>

  • <root level="DEBUG">

  • <appender-ref ref="console_out" />

  • </root>

  • </configuration>

3.2 : 临界值过滤器(ThresholdFilter)

ThresholdFilter 过滤掉低于指定临界值的事件 . 当记录的级别等于或高于临界值时 , ThresholdFilter 的decide()方法会返回NEUTRAL ; 当记录级别低于临界值时 , 事件会被拒绝 下面是个配置文件例子 :
 
   
   
 
  • <?xml version="1.0" encoding="utf-8"?>

  • <configuration>

  • <!-- conf consoel out -->

  • <appender name ="console_out" class="ch.qos.logback.core.ConsoleAppender">

  • <filter class="ch.qos.logback.classic.filter.ThresholdFilter">

  •         <!-- 过滤掉TRACE和DEBUG级别的日志 -->

  • <level>INFO</level>

  • </filter>


  • <encoder>

  • <pattern>%-4relative [%thread] %-5level %logger{30} - %msg%n</pattern>

  • </encoder>

  • </appender>

  • <root level="DEBUG">

  • <appender-ref ref="console_out" />

  • </root>

  • </configuration>

3.3 : 求值过滤器(EvaluatorFilter)

EvaluatorFilter 封装了 EventEvaluator(ch.qos.logback.core.boolex.EventEvaluator) , 评估 是否符合指定的条件
 
   
   
 
  • <?xml version="1.0" encoding="utf-8"?>

  • <configuration>

  • <!-- conf consoel out -->

  • <appender name ="console_out" class="ch.qos.logback.core.ConsoleAppender">

  • <filter class="ch.qos.logback.classic.filter.EvaluatorFilter">

  • <evaluator>

  • <!--过滤掉所有日志中不包含hello字符的日志-->

  • <expression>

  • message.contains("hello")

  • </expression>

  • <onMatch>NEUTRAL</onMatch>

  • <onMismatch>DENY</onMismatch>

  • </evaluator>

  • </filter>


  • <encoder>

  • <pattern>%-4relative [%thread] %-5level %logger{30} - %msg%n</pattern>

  • </encoder>

  • </appender>

  • <root level="DEBUG">

  • <appender-ref ref="console_out" />

  • </root>

  • </configuration>

3.4 : 匹配器(Matchers)

尽管能通过调用 String 类的 matches()方法进行模式匹配,但这会导致每次调用过滤器 时都会创建一个全新的 Pattern 对象。 为消除这种开销,你可以预先定义一个或多个 Matcher 对象。 一旦定义 matcher 后,就可以在求值表达式里重复引用它。

  
    
    
  
  • <?xml version="1.0" encoding="utf-8"?>

  • <configuration>

  • <!-- conf consoel out -->

  • <appender name ="console_out" class="ch.qos.logback.core.ConsoleAppender">

  • <filter class="ch.qos.logback.classic.filter.EvaluatorFilter">

  • <evaluator>

  • <matcher>

  • <Name>odd</Name>

  • <!-- 过滤掉序号为奇数的语句-->

  • <regex>statement [13579]</regex>

  • </matcher>

  • <expression>odd.matches(formattedMessage)</expression>

  • <onMatch>NEUTRAL</onMatch>

  • <onMismatch>DENY</onMismatch>

  • </evaluator>

  • </filter>


  • <encoder>

  • <pattern>%-4relative [%thread] %-5level %logger{30} - %msg%n</pattern>

  • </encoder>

  • </appender>

  • <root level="DEBUG">

  • <appender-ref ref="console_out" />

  • </root>

  • </configuration>


以上就是今天的分享啦~

如果大家有问题或者想了解更多的

技术干货可以加朗妹儿微信哟~


往期精彩回顾




以上是关于Logback使用及配置标签详解的主要内容,如果未能解决你的问题,请参考以下文章

Logback简介及配置文件logback.xml详解

logback配置文件详解

logback介绍和配置详解

logback 常用配置详解(序)logback 简介

logback.xml详解

idea2021.1版本SpringBoot项目日志的说明及使用