基于Spring Boot的Logback日志輪轉(zhuǎn)配置詳解
在生產(chǎn)環(huán)境下,日志是最好的問(wèn)題調(diào)試和跟蹤方法,因此日志的地位是十分重要的。我們平時(shí)經(jīng)常使用的log4j,slf4j,logback等等,他們的配置上大同小異。這里就結(jié)合Spring Boot配置一下Logback的日志。
默認(rèn)最簡(jiǎn)單的配置
默認(rèn)情況下,如果對(duì)日志沒(méi)有特殊處理,可以直接基于application.properties進(jìn)行配置。
常用的參數(shù)有:
logging.level
配置日志的級(jí)別
logging.file logging.path
這兩個(gè)參數(shù)只能配置一個(gè)生效,一個(gè)是文件(可以有絕對(duì)路徑或者相對(duì)路徑);另一個(gè)是路徑,文件的名稱會(huì)默認(rèn)為spring.log
日志默認(rèn)按照大小進(jìn)行切分,由于我這邊沒(méi)有產(chǎn)生那么大的文件,因此沒(méi)有做實(shí)驗(yàn)。
這種方法最簡(jiǎn)單,但是不能處理那種復(fù)雜的日志輪轉(zhuǎn)的機(jī)制。比如沒(méi)天一個(gè)文件這種需求,因此可以考慮使用獨(dú)立的日志文件進(jìn)行配置:
使用獨(dú)立的配置文件配置
如果有復(fù)雜的需求,可以像其他普通的web應(yīng)用一樣,配置獨(dú)立的logback.xml:
首先注意的是這個(gè)文件必須放在resources目錄下(我這邊發(fā)現(xiàn),如果通過(guò)logging.config指向另一個(gè)目錄下的logback.xml會(huì)在程序啟動(dòng)時(shí)報(bào)錯(cuò),報(bào)無(wú)法解析該xml。猜想可能是在其他目錄下的xml都被當(dāng)做spring的配置或者有xml schema信息的配置,單純的logback.xml它不認(rèn)識(shí))
然后在application.properties文件中加入:
# 配置logback logging.config=classpath:logback-spring.xml
即可。
注意如果是logging.config=classpath:xxxx/logback-spring.xml,
就不行了哈!我試過(guò)好多次!
配置的內(nèi)容基本可以參考下面的來(lái):
<?xml version="1.0" encoding="UTF-8"?> <configuration> <!-- 屬性文件 --> <property name="processName" value="xxx"/> <property name="logDir" value="/opt/logs/xxx"/> <!-- 默認(rèn)的控制臺(tái)日志輸出,一般生產(chǎn)環(huán)境都是后臺(tái)啟動(dòng),這個(gè)沒(méi)太大作用 --> <appender name="stdout" class="ch.qos.logback.core.ConsoleAppender"> <!--<Encoding>UTF-8</Encoding>--> <layout class="ch.qos.logback.classic.PatternLayout"> <pattern>%date [%thread] %-5level %logger{50}:%L - %msg%n</pattern> </layout> </appender> <!-- 配置文件輪轉(zhuǎn) --> <appender name="logfile" class="ch.qos.logback.core.rolling.RollingFileAppender"> <!--<Encoding>UTF-8</Encoding>--> <File>${logDir}/service.log</File> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <FileNamePattern>${logDir}/history/service.%d{yyyy-MM-dd}.log.gz</FileNamePattern> <maxHistory>30</maxHistory> </rollingPolicy> <layout class="ch.qos.logback.classic.PatternLayout"> <pattern>%date [%thread] %-5level %logger{50}:%L - %msg%n</pattern> </layout> </appender> <!-- 修改其他包的日志輸出級(jí)別 --> <logger name="org.apache.zookeeper"> <level value="WARN"/> </logger> <!-- root 默認(rèn)日志配置 , 注意這里的級(jí)別哈!小心生產(chǎn)環(huán)境用DEBUG,壓爆你的磁盤(pán)!--> <root level="INFO"> <appender-ref ref="logfile"/> <appender-ref ref="stdout"/> </root> </configuration>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java 創(chuàng)建并應(yīng)用PPT幻燈片母版的方法示例
幻燈片母版可供用戶設(shè)置幻燈片的樣式,本文將介紹如何用Java創(chuàng)建并應(yīng)用單個(gè)或多個(gè)幻燈片母版。感興趣可以了解一下2020-06-06SpringBoot項(xiàng)目如何將Bean注入到普通類中
這篇文章主要介紹了SpringBoot項(xiàng)目如何將Bean注入到普通類中,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-11-11SpringBoot整合數(shù)據(jù)庫(kù)訪問(wèn)層的實(shí)戰(zhàn)
本文主要介紹了SpringBoot整合數(shù)據(jù)庫(kù)訪問(wèn)層的實(shí)戰(zhàn),主要包含JdbcTemplate和mybatis框架的整合應(yīng)用,具有一定的參考價(jià)值,感興趣的可以了解一下2022-03-03如何實(shí)現(xiàn)java8 list按照元素的某個(gè)字段去重
這篇文章主要介紹了如何實(shí)現(xiàn)java8 list按照元素的某個(gè)字段去重,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,,需要的朋友可以參考下2019-06-06如何在SpringBoot項(xiàng)目中集成SpringSecurity進(jìn)行權(quán)限管理
在本文中,我們將討論如何在Spring?Boot項(xiàng)目中集成權(quán)限管理,我們將使用Spring?Security框架,這是一個(gè)專門(mén)用于實(shí)現(xiàn)安全性功能的框架,包括認(rèn)證和授權(quán),需要的朋友可以參考下2023-07-07Java實(shí)現(xiàn)整數(shù)分解質(zhì)因數(shù)的方法示例
這篇文章主要介紹了Java實(shí)現(xiàn)整數(shù)分解質(zhì)因數(shù)的方法,結(jié)合實(shí)力形式分析了質(zhì)因數(shù)分解的原理與實(shí)現(xiàn)方法,涉及java數(shù)值運(yùn)算相關(guān)操作技巧,需要的朋友可以參考下2017-12-12SpringBoot文件上傳大小設(shè)置方式(yml中配置)
這篇文章主要介紹了SpringBoot文件上傳大小設(shè)置方式(yml中配置),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03java反射機(jī)制的一些學(xué)習(xí)心得小結(jié)
這篇文章主要給大家介紹了關(guān)于java反射機(jī)制的一些學(xué)習(xí)心得,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02