关于logback日志级别的配置

logback如果需要灵活的配置日志级别,需要结合过滤器,<filter></fiter>这个标签。需要注意的是,过滤器过滤的基础是在root标签的配置基础上进行的。

过滤器可以写在appender标签内,可以写一个或多个,顺序执行。过滤器会对每个级别的日志设置枚举值,表示对日志的处理方式。

  DENY:日志将立即被抛弃不再经过其他过滤器;

  NEUTRAL:有序列表里的下个过滤器过接着处理日志;

  ACCEPT:日志会被立即处理,不再经过剩余过滤器。

下面讲述两个常用的filter:

1、级别过滤器

  LevelFilter: 级别过滤器,对特定某个级别的日志进行过滤。

<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="false">
    
    <!-- 控制台输出 -->
    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <!-- 1格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符-->
            <pattern></pattern>
            <charset>utf-8</charset>
        </encoder>
        <!-- 过滤掉非info的日志 -->
         <filter class="ch.qos.logback.classic.filter.LevelFilter">   
              <level>INFO</level>   
              <onMatch>ACCEPT</onMatch>   
              <onMismatch>DENY</onMismatch>   
          </filter>   
    </appender>
    
    
    <!-- 日志级别排序为: TRACE < DEBUG < INFO < WARN < ERROR -->
    <!-- 日志输出级别 -->
    <root level="DEBUG">
        <appender-ref ref="STDOUT" />
        <appender-ref ref="FILE" />
    </root>
</configuration>

level:日志级别。

onMatch:对符合过滤级别的日志的操作。(DENY,NEUTRAL,ACCEPT)

onMismatch:对不符合过滤级别的日志的操作。(DENY,NEUTRAL,ACCEPT)

注意:过滤器的配置在配置级别的基础上过滤,即root标签的配置级别。本例中,是对大于等于debug级别的日志过滤,且只保留info级别的日志打印到控制台。

2、临界值过滤器

ThresholdFilter: 临界值过滤器,过滤掉低于指定临界值的日志。

它没有过多的参数,只有默认配置。当日志级别等于或高于临界值时,过滤器返回NEUTRAL;当日志级别低于临界值时,日志返回DENY。

<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="false">
    
    <!-- 控制台输出 -->
    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <!-- 1格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符-->
            <pattern></pattern>
            <charset>utf-8</charset>
        </encoder>
       <!--临界值日志过滤级别配置 -->
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter"><!-- 只打印DEBUG日志 --> 
            <!-- 在日志配置级别的基础上过滤掉info级别以下的日志 -->
            <level>INFO</level> 
        </filter> 
    </appender>  
    </appender>
    
    
    <!-- 日志级别排序为: TRACE < DEBUG < INFO < WARN < ERROR -->
    <!-- 日志输出级别 -->
    <root level="DEBUG">
        <appender-ref ref="STDOUT" />
        <appender-ref ref="FILE" />
    </root>
</configuration>

本例:在debug配置级别的基础上,过滤掉info一下的日志。最终,info及大于info级别的日志打印的控制台,info以下,debug及debug以上的日志,交给后续的过滤器处理。如果没有后续过滤器就不处理。

猜你喜欢

转载自www.cnblogs.com/whalesea/p/10950628.html