使用springboot logback動態(tài)獲取application的配置項(xiàng)
springboot logback動態(tài)獲取application的配置項(xiàng)
在多環(huán)境的情況下,logback的日志路徑需要進(jìn)行針對性配置,也就是需要通過application.yml文件中進(jìn)行配置。
logback自身支持以下方式配置
<property name="USER_HOME" value="/home/sebastien" />
但是怎樣才能靈活的配置“/home/sebastien”參數(shù)呢,如果不同的環(huán)境此參數(shù)值不同,那么就需要通過application.yml文件的配置項(xiàng)進(jìn)行指定。
但是logback.xml加載早于application.yml,如果直接通過${參數(shù)key}的形式獲取是無法獲取到對應(yīng)參數(shù)值的。
因此只能使用spring提供的標(biāo)簽來對此參數(shù)進(jìn)行配置
<springProperty scope="context" name="LOG_HOME" source="logback.file"/>
對照上面的配置,其中property替換成了springProperty標(biāo)簽。兩個(gè)配置屬性name效果是一樣的,只不過后者的source指向了application.yml文件中的key。注意此處不需要${}形式獲取。
springboot logback配置及動態(tài)配置log目錄
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<contextName>xxx-server</contextName>
<property name="pattern" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg %n"/>
<property name="pattern-color" value="%yellow(%d{yyyy-MM-dd HH:mm:ss.SSS}) [%thread] %highlight(%-5level) %green(%logger{50}) - %highlight(%msg) %n"/>
<define name="LOG_HOME" class="com.youzu.dc.dcopsserver.config.LoggerConfig" />
<!-- 控制臺輸出 -->
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<pattern>${pattern}</pattern>
</encoder>
</appender>
<!-- 控制臺輸出-帶顏色 -->
<appender name="CONSOLE-WITH-COLOR" class="ch.qos.logback.core.ConsoleAppender">
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<pattern>${pattern-color}</pattern>
</encoder>
</appender>
<!-- 文件輸出 -->
<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${LOG_HOME}/xxxx.%d.%i.log</fileNamePattern>
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
<maxFileSize>100MB</maxFileSize>
</timeBasedFileNamingAndTriggeringPolicy>
<maxHistory>30</maxHistory>
<totalSizeCap>3GB</totalSizeCap>
</rollingPolicy>
<encoder>
<pattern>${pattern}</pattern>
</encoder>
</appender>
<root level="INFO">
<appender-ref ref="CONSOLE-WITH-COLOR"/>
<appender-ref ref="FILE"/>
</root>
</configuration>
子節(jié)點(diǎn)一 appender
appender用來格式化日志輸出節(jié)點(diǎn),有倆個(gè)屬性name和class,class用來指定哪種輸出策略,常用就是控制臺輸出策略和文件輸出策略。
控制臺輸出appender
<property name="pattern" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg %n"/>
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<pattern>${pattern}</pattern>
</encoder>
</appender>
encoder表示輸出格式,具體說明如下:
- %d表示時(shí)間
- %thread表示線程名
- %-5level 表示日志級別,允許以五個(gè)字符長度輸出
- %logger{50}表示具體的日志輸出者,比如類名,括號內(nèi)表示長度
- %msg表示具體的日志消息,就是logger.info(“xxx”)中的xxx
- %n表示換行
文件輸入appender
文件輸出主要包括配置:以指定格式將日志輸出到指定文件夾下的文件中,可以配置該文件的名稱、最大大小、保存時(shí)間
例如:
<property name="LOG_HOME" value="logs"/>
<property name="pattern" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg %n"/>
<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${LOG_HOME}/all.%d.%i.log</fileNamePattern>
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
<maxFileSize>10MB</maxFileSize>
</timeBasedFileNamingAndTriggeringPolicy>
<maxHistory>30</maxHistory>
</rollingPolicy>
<encoder>
<pattern>${pattern}</pattern>
</encoder>
</appender>
上述配置的主要內(nèi)容是:以指定的格式向logs文件下的文件輸出日志,文件名稱格式被指定為logs/all.日期.索引號.log,日志文件最大大小為10MB,超出則創(chuàng)建新文件,日志文件保留三十天
索引從0開始遞增
rollingPolicy指滾動粗略,具體配置如上。
關(guān)于日志文件大小限制也可以使用1GB配置。
root節(jié)點(diǎn)-啟用配置
root節(jié)點(diǎn)實(shí)際上是配置啟用哪種appender,可以添加多個(gè)appender。
比如:
<root level="INFO"> <appender-ref ref="CONSOLE-WITH-COLOR"/> <appender-ref ref="FILE"/> </root>
表示level為info級別,啟用渲染器CONSOLE-WITH-COLOR和FILE。
按照這樣配置,輸出日志時(shí),控制臺會按照CONSOLE定義的格式輸出,而日志文件會按照CONSOLE-WITH-COLOR的配置去輸出。
動態(tài)配置log目錄
import ch.qos.logback.core.PropertyDefinerBase
class LoggerConfig : PropertyDefinerBase() {
override fun getPropertyValue(): String {
return "${ServerConfig.applicationPath}/logs"
}
}
獲取jar目錄路徑
/**
* 獲取jar的絕對路徑文件夾
*/
fun getApplicationPath(): String {
val h = ApplicationHome(FileUtils::class.java)
return h.source.parentFile.toString()
}
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家.
- SpringBoot整合logback日志的詳細(xì)步驟
- SpringBoot中項(xiàng)目如何讀取外置logback配置文件
- 解決springboot配置logback-spring.xml不起作用問題
- Springboot使用Logback實(shí)現(xiàn)日志配置與異常記錄
- SpringBoot項(xiàng)目讀取外置logback配置文件的問題及解決
- springboot logback如何從apollo配置中心讀取變量
- springboot 使用logback啟動報(bào)警報(bào)錯(cuò)的解決
- 詳解Springboot之Logback的使用學(xué)習(xí)
- 解決springboot使用logback日志出現(xiàn)LOG_PATH_IS_UNDEFINED文件夾的問題
- Springboot整合logback的詳細(xì)教程
相關(guān)文章
Java獲取Cookie里的指定值的實(shí)現(xiàn)方法
在Java中,我們經(jīng)常需要從HTTP請求中獲取Cookie,并從中提取特定的值,下面我們將介紹如何通過Java代碼獲取Cookie中的指定值,文章通過代碼示例介紹的非常詳細(xì),需要的朋友可以參考下2024-09-09
java?web項(xiàng)目Session獲取不到問題及解決
這篇文章主要介紹了java?web項(xiàng)目Session獲取不到問題及解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01
springboot配合Thymeleaf完美實(shí)現(xiàn)遍歷功能
Thymeleaf顯然是一個(gè)開發(fā)頁面的技術(shù),現(xiàn)在各種前端技術(shù)層出不窮,比如現(xiàn)在主流的Vue、React、AngularJS等。這篇文章主要介紹了springboot配合Thymeleaf完美實(shí)現(xiàn)遍歷,需要的朋友可以參考下2021-09-09
Java如何接收并解析HL7協(xié)議數(shù)據(jù)
文章主要介紹了HL7協(xié)議及其在醫(yī)療行業(yè)中的應(yīng)用,詳細(xì)描述了如何配置環(huán)境、接收和解析數(shù)據(jù),以及與前端進(jìn)行交互的實(shí)現(xiàn)方法,文章還分享了使用7Edit工具進(jìn)行調(diào)試的經(jīng)驗(yàn),并記錄了一個(gè)常見的解析問題及其解決方法2024-12-12

