logback EvaluatorFilter实现同时记录多个level级别的日志

 更新时间:2023年11月17日 11:25:25   作者:爱游泳的老白  
这篇文章主要介绍了logback EvaluatorFilter实现同时记录多个level级别的日志方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

Java技术迷

使用求值过滤器

为了方便日志查看,想将不同level的日志输出到同一个日志文件里.例如:我想将trace & debug级别的日志输出到一个文件里.这时候使用求值过滤器:ch.qos.logback.core.filter.EvaluatorFilter就非常方便了.

1
2
3
4
5
6
7
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">        
    <evaluator> <!-- 默认为 ch.qos.logback.classic.boolex.JaninoEventEvaluator -->  
      <expression>return message.contains("billing");</expression>  
    </evaluator>  
    <OnMatch>ACCEPT </OnMatch
    <OnMismatch>DENY</OnMismatch
</filter>  

evaluator: 它以任意的java布尔值表达式作为求值条件,求值条件在配置文件解释过成功被动态编译,布尔值表达式返回true就表示符合过滤条件。evaluator有个子标签<expression>,用于配置求值条件。

expression: 求值表达式作用于当前日志

logback向求值表达式暴露日志的各种字段

例子

输出DEBUG&TRACE的信息到一个日志文件里

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
<!-- 输出DEBUG&TRACE的信息到日志文件里 -->
<appender name="FILE-SQL" class="ch.qos.logback.core.rolling.RollingFileAppender">
  <filter class="ch.qos.logback.core.filter.EvaluatorFilter">        
    <evaluator>
      <!-- DEBUG=10000 TRACE=5000 -->
      <expression><![CDATA[ return (level==10000 || level==5000); ]]></expression>  
    </evaluator>  
    <OnMatch>ACCEPT </OnMatch
    <OnMismatch>DENY</OnMismatch
  </filter>  
  <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
    <!-- rollover daily -->
    <fileNamePattern>${LOG_DIR}/sql_dev_%d{yyyy-MM-dd}_%i.log</fileNamePattern>
    <!-- each file should be at most 100MB, keep 30 days worth of history, but at most 10GB -->
    <maxFileSize>100MB</maxFileSize>   
    <maxHistory>30</maxHistory>
    <totalSizeCap>10GB</totalSizeCap>
  </rollingPolicy>
  <encoder>
    <pattern>${LOG_PATTERN}</pattern>
    <charset>UTF-8</charset>
  </encoder>
</appender>

注意: EvaluatorFilter需要依赖动态编译器janino,可以使用下面的方式来引入:

Maven:

1
2
3
4
5
<dependency>
  <groupId>org.codehaus.janino</groupId>
  <artifactId>janino</artifactId>
  <version>3.1.8</version>
</dependency>

Gradle:

1
implementation 'org.codehaus.janino:janino:3.1.8'

以上就是logback EvaluatorFilter实现同时记录多个level级别的日志的详细内容,更多关于logback EvaluatorFilter日志记录的资料请关注脚本之家其它相关文章!

蓄力AI

微信公众号搜索 “ 脚本之家 ” ,选择关注

程序猿的那些事、送书等活动等着你

原文链接:https://blog.csdn.net/wjw465150/article/details/126749684

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权/违法违规/事实不符,请将相关资料发送至 reterry123@163.com 进行投诉反馈,一经查实,立即处理!

相关文章

  • Intelli IDEA安装Scala插件并安装Scala软件和配置环境变量的详细教程

    Intelli IDEA安装Scala插件并安装Scala软件和配置环境变量的详细教程

    这篇文章主要介绍了Intelli IDEA安装Scala插件并安装Scala软件和配置环境变量的详细教程,需要的朋友可以参考下
    2020-10-10
  • 从dubbo源码分析qos-server端口冲突问题及解决

    从dubbo源码分析qos-server端口冲突问题及解决

    这篇文章主要介绍了从dubbo源码分析qos-server端口冲突问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02
  • Java之键盘输入语句Scanner解读

    Java之键盘输入语句Scanner解读

    这篇文章主要介绍了Java之键盘输入语句Scanner解读,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • Java GZIP压缩与解压缩代码实例

    Java GZIP压缩与解压缩代码实例

    这篇文章主要介绍了Java GZIP压缩与解压缩代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-01-01
  • Java 负载均衡的 5 种算法实现原理

    Java 负载均衡的 5 种算法实现原理

    这篇文章主要介绍Java 负载均衡的 5 种算法实现原理,负载均衡能够平均分配客户请求到服 务器阵列,借此提供快速获取重要数据,解决大量并发访问服务问题,这种集群技术可以用最少的投资获得接近于大型主机的性能。下面就来看看文章的具体内容吧
    2021-10-10
  • 使用spring拦截器实现日志管理实例

    使用spring拦截器实现日志管理实例

    本篇文章主要介绍了使用spring拦截器实现日志管理实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
    2017-03-03
  • java生成sm2/hutool生成公钥私钥代码示例

    java生成sm2/hutool生成公钥私钥代码示例

    这篇文章主要给大家介绍了关于java生成sm2/hutool生成公钥私钥的相关资料,Java是一种广泛使用的编程语言,可以用来生成公钥和私钥文件,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2023-09-09
  • 详解如何实现SpringBoot的底层注解

    详解如何实现SpringBoot的底层注解

    今天给大家带来的文章是如何实现SpringBoot的底层注解,文中有非常详细的介绍及代码示例,对正在学习java的小伙伴很有帮助,需要的朋友可以参考下
    2021-06-06
  • Mybatis-Plus中分页插件PaginationInterceptor的使用

    Mybatis-Plus中分页插件PaginationInterceptor的使用

    我们在开发的过程中,经常会遇到分页操作,本文主要介绍了Mybatis-Plus中分页插件PaginationInterceptor的使用,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06
  • Java获取磁盘空间的两种代码示例

    Java获取磁盘空间的两种代码示例

    这篇文章主要介绍了Java获取磁盘空间的两种代码示例,没什么事的时候可以拿来玩玩,需要的朋友参考下。
    2017-11-11

最新评论