logback如果需要灵活的配置日志级别,需要结合过滤器,这个标签。需要注意的是,过滤器过滤的基础是在root标签的配置基础上进行的。
过滤器可以写在appender标签内,可以写一个或多个,顺序执行。过滤器会对每个级别的日志设置枚举值,表示对日志的处理方式。
DENY:日志将立即被抛弃不再经过其他过滤器;
NEUTRAL:有序列表里的下个过滤器过接着处理日志;(该级别既不处理,也不抛弃,相当于没  有任何处理,日志会被保存下来并在本appender被执行)
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)
测试代码:

@Controller
public class HelloController {Logger logger = LoggerFactory.getLogger(HelloController.class);@ResponseBody@RequestMapping("/hello")public ResultModel hello() {logger.trace("*****************trace**********");logger.debug("*************debug*************");logger.info("**************info****************");logger.warn("****************warn***************");logger.error("****************error*************");return ResultModel.ok("hello,dbzx"+new Date().getTime());}}

结果:

2019-05-30 17:21:19.413 [http-nio-8888-exec-1]
INFO  com.dbzx.controller.HelloController - **************info****************

过滤器的配置在配置级别的基础上过滤,即root标签的配置级别。本例中,是对大于等于debug级别的日志过滤。

ps:如果修改onMismatch参数为NEUTRAL。

        <filter class="ch.qos.logback.classic.filter.LevelFilter">   <level>INFO</level>   <onMatch>ACCEPT</onMatch>   <onMismatch>NEUTRAL</onMismatch>   </filter> 
2019-05-30 17:25:08.045 [http-nio-8888-exec-1] DEBUG com.dbzx.controller.HelloController - *************debug*************
2019-05-30 17:25:08.045 [http-nio-8888-exec-1] INFO  com.dbzx.controller.HelloController - **************info****************
2019-05-30 17:25:08.045 [http-nio-8888-exec-1] WARN  com.dbzx.controller.HelloController - ****************warn***************
2019-05-30 17:25:08.046 [http-nio-8888-exec-1] ERROR com.dbzx.controller.HelloController - ****************error*************

结果就是:出了info级别,debug、warn、error级别的日志也会被打印,即不符合配置级别的日志,同样被执行。


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>

结果:

2019-05-30 17:26:42.755 [http-nio-8888-exec-1] INFO  com.dbzx.controller.HelloController - **************info****************
2019-05-30 17:26:42.755 [http-nio-8888-exec-1] WARN  com.dbzx.controller.HelloController - ****************warn***************
2019-05-30 17:26:42.756 [http-nio-8888-exec-1] ERROR com.dbzx.controller.HelloController - ****************error*************

在debug配置级别的基础上,过滤掉info一下的日志。最终,info及大于info级别的日志打印的控制台,info以下,debug及debug以上的日志,被抛弃掉。

logback日志过滤器相关推荐

  1. Logback 日志过滤器的使用-日志分类归档方案

    文章目录 前言 1. Logback 过滤器的分类 2. 常规过滤器 2.1 日志级别过滤器 LevelFilter 2.2 日志评估过滤器 EvaluatorFilter JaninoEventEv ...

  2. SpringMVC学习(三)——SpringMVC+Slf4j+Log4j+Logback日志集成实战分享

    文章目录 1.概述 1.1 说明 1.2 日志体系 1.2.1 JCL日志面门介绍 1.2.2 Slf4j日志面门介绍 2.几种日志系统介绍: 2.1 Slf4j 2.2 Commons-loggin ...

  3. java 如何去掉http debug日志_Spring Boot手把手教学(3):从零配置logback日志

    前言 使用logback我们可以自定义控制台日志输出,可以实现对不同日志不同级别打印到不同的文件中,可以对日志进行归档保存,并定时删除: 对于一个应用来讲,一个好的日志系统,对于对问题的追溯有很大的帮 ...

  4. logback filter过滤器简介说明

    转自: logback filter过滤器简介说明 下文笔者讲述logback中filter过滤器的简介说明,如下所示: Logback提供两类Filter Regular Filter;Turbo ...

  5. 【SSM基础】Logback日志管理

    [SSM基础]Logback日志管理 其他文章: bookcase微服务实战 1.前言 这篇我们说下日志管理,业界常用的日志管理一共有几种: java.util.Logging,Log4j,Log4j ...

  6. Logback日志跨线程追踪实践

    Logback日志跨线程追踪实践 当我们程序在服务器上面跑的时候,是不是很多时候很难定位问题? 当一大堆繁杂的日志文件丢给你的时候,你如何能从中定位到问题? 本项目源码已经上传Github: gith ...

  7. springboot使用logback日志,部署到tomcat不生效问题解决

    springboot使用logback日志,部署到tomcat不生效问题解决 参考文章: (1)springboot使用logback日志,部署到tomcat不生效问题解决 (2)https://ww ...

  8. Logback日志系统配置攻略

    logback是log4j作者推出的新日志系统,原生支持slf4j通用日志api,允许平滑切换日志系统,并且对简化应用部署中日志处理的工作做了有益的封装. 官方地址为:http://logback.q ...

  9. logback日志记录器讲解

    我们看一下日志记录器的支持,logback,既支持log4j,也支持logback,找到我们的pom文件,然后看一下他的注入包,在这里我们可以看到有log4j的jar包,有slf4j的,还有logba ...

最新文章

  1. hdu4920 矩阵乘法%3
  2. freemarker该阵列
  3. boost::::adaptors::indexed::indexed相关的测试程序
  4. org.hibernate.LazyInitializationException: could not initialize proxy - no Session
  5. ROS笔记(13) 记录与回放数据
  6. leetcode lcp2 分式化简
  7. 2021 ACDU China Tour-北京站暨数据库大咖讲坛(第3期)成功举办!(附PPT下载)
  8. windows curl ssl版本编译
  9. 持久化存储技术之本地存储
  10. c++11 多线程编程(六)------条件变量(Condition Variable)
  11. 【超级综述】BERT、GPT-3们有了新名字:Percy Liang、李飞飞等发布200多页综述,阐述大模型机遇与风险...
  12. 【BZOJ2655】—calc(拉格朗日插值+生成函数+dp)
  13. yoloV3运行速度测试报告
  14. 家庭用计算机选购调查报告,【调查报告】计算机选购调查报告.doc
  15. c语言中布尔类型字节数,【C语言】中的布尔类型
  16. 中国越野汽车电子市场趋势报告、技术动态创新及市场预测
  17. React中文文档之Handling Events
  18. 菜鸟窝Android百度云视频,菜鸟窝React Native 视频系列教程
  19. 伟景行citymaker-----01.javascript打开本地模型CEP,加载目录树,加载要素类
  20. 在word中插入excel文件

热门文章

  1. 亚洲信贷监察:数据分析让应收账款管理更智能
  2. JSLint使用教程
  3. win11系统右键菜单修改win10风格 Win11右键菜单修改成win10教程
  4. 如何减少超市的提货和包装错误
  5. java多线程之~生产者消费者
  6. 《Splunk智能运维实战》——2.2 使原始事件数据具备可读性
  7. 教你如何设置虚拟机共享文件夹
  8. 拜占庭容错的三个基本理论(CAP/FLP/DLS)
  9. Vue3引入彩色阿里巴巴Iconfont图标
  10. 【心有猛虎】react-pxq