欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

Spring如何动态自定义logback日志目录详解

时间:2021-05-10 08:41:44|栏目:JAVA代码|点击:

问题场景

一般情况下,日志打印的内容都是根据配置文件中配置的pattern格式指定好的。在我们调用logger.info(), logger.debug()等日志打印方法时,打印的内容格式与配置文件中的pattern格式一致。

例如,在logback.xml配置文件中指定了日志打印格式:

%d{HH:mm:ss.SSS} %-5level [%thread][%logger{0}-%L] %msg%n"。

这些格式的意义在官网的文档上都有说明。其中%msg就是我们调用日志打印方法时输入的内容。

当官方指定的这些格式不能满足我们的需求,或者是我们需要在打印日志的时候,需要加上一些比较有规律的内容,例如打印本机的hostname/ip等logback本身没有提供的格式的时候,我们就可以自定义日志输出的内容与格式。

最近在业务开发中,就 遇到一个场景. 日志目录需要根据不同的一个业务id存储. 故需要动态存储logback的日志,下面话不多说了,来一起看看详细的介绍吧

解决办法

在springboot中, 或者spring相关框架中, 可以通过实现logback的PropertyDefinerBase方法来动态决定日志目录.

// 通过实现logback的PropertyDefinerBase方法,动态定义logback配置中的变量
@Component
public class DefineDir extends PropertyDefinerBase {

 @Override
 public String getPropertyValue() {
  return "动态参数";
 }
}
<configuration>

 // 通过DefineDir类映射自定义变量, 实现动态修改logback的日志目录
 <define name="dirXxx" class="com.xxx.DefineDir" />

 <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
  <file>../logs/${dirXxx}/info.log</file>
  <encoder>
   <charset>UTF-8</charset>
   <pattern>%d{yyyy/MM/dd HH:mm:ss.SSS} [%thread] [%X{requestId}] %-5level %logger{36} - %msg%n</pattern>
  </encoder>
 </appender>

 <root level="INFO">
  <appender-ref ref="FILE" />
 </root>
</configuration>

总结

上一篇:Java实现将png格式图片转换成jpg格式图片的方法【测试可用】

栏    目:JAVA代码

下一篇:java根据不同的参数调用不同的实现类操作

本文标题:Spring如何动态自定义logback日志目录详解

本文地址:http://www.codeinn.net/misctech/118193.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有