logback使用filter过滤日志操作
作者:justry_deng 时间:2022-07-11 03:20:27
笔者语录: 我发现我喜欢捣鼓一些小玩意儿,虽然官网(见文末)写得很明白了,但是咱们对感兴趣的部分来敲一遍代码好吧。
过滤器简介:
简介
logback具有过滤器支持。logbcak允许给日志记录器appender配置一个或多个Filter(或者给整体配置一个或多个TurboFilter),来控制:当满足过滤器指定的条件时,才记录日志(或不满足条件时,拒绝记录日志)。logback支持自定义过滤器,当然logback也自带了一些常用的过滤器,在绝大多数时候,自带的过滤器其实就够用了,一般是不需要自定义过滤器的。
logback提供的过滤器支持主要分两大类
ch.qos.logback.core.filter.Filter
ch.qos.logback.classic.turbo.TurboFilter
过滤器 | 来源 | 说明 | 相对常用 |
---|---|---|---|
LevelFilter | Filter | 对指定level的日志进行记录(或不记录),对不等于指定level的日志不记录(或进行记录) | 是 |
ThresholdFilter | Filter | 对大于或等于指定level的日志进行记录(或不记录),对小于指定level的日志不记录(或进行记录) 提示:info级别是大于debug的 | 是 |
EvaluatorFilter | Filter | 对满足指定表达式的日志进行记录(或不记录),对不满足指定表达式的日志不作记录(或进行记录) | 是 |
MDCFilter | TurboFilter | 若MDC域中存在指定的key-value,则进行记录,否者不作记录 | 是 |
DuplicateMessageFilter | TurboFilter | 根据配置不记录多余的重复的日志 | 是 |
MarkerFilter | TurboFilter | 针对带有指定标记的日志,进行记录(或不作记录) | 否 |
… | … | … | … |
若过滤器已经返回了需要记录,那么就一定会对该日志进行记录(不论当前日志的level是否大于等于系统设置的最低日志级别)。
TurboFilter的性能是优于Filter的,这是因为TurboFilter的作用时机是在创建日志事件ILoggingEvent对象之前,而Filter的作用时机是在创建之后。若一个日志注定是会被过滤掉不记录的,那么创建ILoggingEvent对象(包括后续的参数组装方法调用等)这个步骤无疑是非常消耗性能的。
过滤器的FilterReply状态枚举:
对于Filter而言,需不需要记录日志,取决于ch.qos.logback.core.filter.Filter#decide方法的返回:
Filter与TurboFilter自带的几种常用过滤器
对于TurboFilter而言,需不需要记录日志,取决于ch.qos.logback.classic.turbo.TurboFilter#decide方法的返回:
可以看到,返回的都是FilterReply这个枚举:
FilterReply有三种枚举值:
DENY:表示不用看后面的过滤器了,这里就给拒绝了,不作记录。
NEUTRAL:表示需不需要记录,还需要看后面的过滤器。若所有过滤器返回的全部都是NEUTRAL,那么需要记录日志。
ACCEPT:表示不用看后面的过滤器了,这里就给直接同意了,需要记录。
过滤器的使用(示例):
使用LevelFilter的logback.xml(示例):
测试一下:
编写测试方法:
运行方法,产出日志:
使用ThresholdFilter的logback.xml(示例):
测试一下:
编写测试方法:
运行方法,产出日志:
使用EvaluatorFilter的logback.xml(示例):
需要引入额外的解析库依赖janino:
<dependency>
<groupId>org.codehaus.janino</groupId>
<artifactId>janino</artifactId>
<version>3.1.2</version>
</dependency>
logbaxk.xml
测试一下:
编写测试方法:
运行方法,产出日志:
使用MDCFilter的logback.xml(示例):
测试一下:
编写测试方法:
运行方法,产出日志:
自定义过滤器:
自定义Filter:
编写自定义Filter
在logback.xml中配置使用此过滤器
测试一下:
编写测试方法:
运行方法,产出日志:
自定义TurboFilter:
编写自定义TurboFilter
在logback.xml中配置使用此过滤器
测试一下:
编写测试方法:
运行方法,产出日志:
logback使用filter过滤日志,初步学习完毕!
来源:https://blog.csdn.net/justry_deng/article/details/108074525
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
java分页工具类的使用方法
使用Swing绘制动态时钟
![](https://img.aspxhome.com/file/2023/6/59166_0s.gif)
SpringBoot之通过BeanPostProcessor动态注入ID生成器案例详解
![](https://img.aspxhome.com/file/2023/1/59251_0s.jpg)
C#中HttpWebRequest的用法详解
SpringCloud Eureka实现服务注册与发现
![](https://img.aspxhome.com/file/2023/9/63499_0s.png)
SpringMVC利用dropzone组件实现图片上传
Java中如何动态创建接口的实现方法
![](https://img.aspxhome.com/file/2023/9/60259_0s.png)
IDEA解决springboot热部署失效问题(推荐)
![](https://img.aspxhome.com/file/2023/8/58148_0s.png)
解决SpringBoot框架因post数据量过大没反应问题(踩坑)
spring中向一个单例bean中注入非单例bean的方法详解
![](https://img.aspxhome.com/file/2023/7/62167_0s.png)
C# GDI+实现时钟表盘
![](https://img.aspxhome.com/file/2023/7/66117_0s.jpg)
java中String字符串删除空格的七种方式
![](https://img.aspxhome.com/file/2023/1/63311_0s.jpg)
详解在Spring中如何自动创建代理
![](https://img.aspxhome.com/file/2023/2/59172_0s.png)
Java技巧函数方法实现二维数组遍历
![](https://img.aspxhome.com/file/2023/9/58469_0s.png)
Java设计模式之单例和原型
Android开发之DrawerLayout实现抽屉效果
![](https://img.aspxhome.com/file/2023/5/85975_0s.png)
IntelliJ IDEA Run时报“无效的源发行版:16“错误问题及解决方法
![](https://img.aspxhome.com/file/2023/5/62455_0s.png)