美文网首页
Logback的Filters详解

Logback的Filters详解

作者: 早点起床晒太阳 | 来源:发表于2020-05-25 16:47 被阅读0次

并不是懂很多,只是官网的搬运工
参考资料: http://logback.qos.ch/manual/filters.html

概念讲解

我们在讲之前需要了解几个概念
DENY,NEUTRAL和ACCEPT
这三个值是通过调用Filter的decide()方法的返回值。(如果需要实现自己的Filter,也是需要实现Filter的decide()方法的,这个一会说明).
如果返回值为DENY,那么此日志将会被放弃并且不会被剩余的过滤器考虑。
如果返回值为NEUTRAL,那么将会经过下一个过滤器。如果没有了其他的过滤器,那么日志事件会被正常处理
如果返回值为ACCEPT,那么将会立即处理日志,并且跳过后续的过滤器(如果有的话)

过滤器

常规过滤器

1、LevelFilter

LevelFilter根据精确的级别匹配过滤事件。如果事件的级别等于已配置的级别,则过滤器将接受或拒绝事件,具体取决于onMatch和onMismatch属性的配置。比如

<configuration>
  <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
    <filter class="ch.qos.logback.classic.filter.LevelFilter">
      <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" />
  </root>
</configuration>
2、ThresholdFilter

该过滤器过滤低于指定阈值的事件。对于等于或高于阈值的事件,响应为NEUTRAL 即交给后续过滤器处理,如果没有则正常处理日志事件。级别低于阈值的事件将被拒绝。比如

<configuration>
  <appender name="CONSOLE"
    class="ch.qos.logback.core.ConsoleAppender">
    <!-- deny all events with a level below INFO, that is TRACE and DEBUG -->
    <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
      <level>INFO</level>
    </filter>
    <encoder>
      <pattern>
        %-4relative [%thread] %-5level %logger{30} - %msg%n
      </pattern>
    </encoder>
  </appender>
  <root level="DEBUG">
    <appender-ref ref="CONSOLE" />
  </root>
</configuration>

自定义过滤器

实现自定义过滤器很容易。要做的就是扩展Filter抽象类并实现该 decide()方法。

总结

看到官网还有很多种,这里不一一说明。只列举几种常用的,如果后续有更复杂的日志管理在补后续。

相关文章