介绍
小编给大家分享一下弹簧动态自定义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日志目录的示例