弹簧动态自定义logback日志目录的示例

  介绍

小编给大家分享一下弹簧动态自定义logback日志目录的示例,希望大家阅读完这篇文章之后都有所收获、下面让我们一起去探讨吧!

<强>问题场景

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

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

% d {HH: mm: ss.SSS} % 5水平[%线程][%记录器{0}- % L] %味精% n"。

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

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

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

<强>解决办法

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

//,通过实现logback的PropertyDefinerBase方法,动态定义logback配置中的变量
  @ component
  public  class  DefineDir  extends  PropertyDefinerBase  {
  
  ,@Override
  ,public  String  getPropertyValue (), {
  return 才能“动态参数“;
  ,}
  }
& lt; configuration>      ,//通过DefineDir类映射自定义变量,,实现动态修改logback的日志目录   ,& lt; define  name=癲irXxx",类=癱om.xxx.DefineDir",/比;      ,& lt; appender  name=癋ILE",类=癱h.qos.logback.core.rolling.RollingFileAppender"比;   & lt;才能file> . ./日志/$ {dirXxx}/info.log   & lt;才能encoder>   ,,& lt; charset> UTF-8   ,,& lt; pattern> % d {yyyy/MM/dd  HH: MM: ss.SSS},[%线程],[X % {requestId}], % 5 level  %记录器{36},安康;%味精% n   & lt;才能/encoder>   ,& lt;/appender>      ,& lt; root 水平=癐NFO"比;   & lt;才能appender-ref  ref=癋ILE",/比;   ,& lt;/root>   & lt;/configuration>

看完了这篇文章,相信你对“春动态自定义logback日志目录的示例”有了一定的了解,如果想了解更多相关知识,欢迎关注行业资讯频道,感谢各位的阅读!

弹簧动态自定义logback日志目录的示例