国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > Java > 正文

Spring如何動態自定義logback日志目錄詳解

2024-07-14 08:42:37
字體:
來源:轉載
供稿:網友

問題場景

一般情況下,日志打印的內容都是根據配置文件中配置的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配置中的變量@Componentpublic 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>

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VeVb武林網的支持。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 都江堰市| 济源市| 广元市| 南阳市| 凉城县| 南江县| 宁河县| 邵东县| 镇江市| 石景山区| 张北县| 望都县| 文水县| 太康县| 库伦旗| 德化县| 夏河县| 白银市| 贡山| 全椒县| 平邑县| 双鸭山市| 贺州市| 延边| 弥渡县| 竹山县| 巩义市| 苍山县| 水富县| 土默特右旗| 盘山县| 九台市| 周宁县| 邻水| 精河县| 阜南县| 麻栗坡县| 阿坝县| 五原县| 广宁县| 敖汉旗|