您好,登錄后才能下訂單哦!
在生產(chǎn)環(huán)境下,日志是最好的問題調(diào)試和跟蹤方法,因此日志的地位是十分重要的。我們平時經(jīng)常使用的log4j,slf4j,logback等等,他們的配置上大同小異。這里就結(jié)合Spring Boot配置一下Logback的日志。
默認(rèn)最簡單的配置
默認(rèn)情況下,如果對日志沒有特殊處理,可以直接基于application.properties進(jìn)行配置。
常用的參數(shù)有:
logging.level
配置日志的級別
logging.file logging.path
這兩個參數(shù)只能配置一個生效,一個是文件(可以有絕對路徑或者相對路徑);另一個是路徑,文件的名稱會默認(rèn)為spring.log
日志默認(rèn)按照大小進(jìn)行切分,由于我這邊沒有產(chǎn)生那么大的文件,因此沒有做實驗。
這種方法最簡單,但是不能處理那種復(fù)雜的日志輪轉(zhuǎn)的機制。比如沒天一個文件這種需求,因此可以考慮使用獨立的日志文件進(jìn)行配置:
使用獨立的配置文件配置
如果有復(fù)雜的需求,可以像其他普通的web應(yīng)用一樣,配置獨立的logback.xml:
首先注意的是這個文件必須放在resources目錄下(我這邊發(fā)現(xiàn),如果通過logging.config指向另一個目錄下的logback.xml會在程序啟動時報錯,報無法解析該xml。猜想可能是在其他目錄下的xml都被當(dāng)做spring的配置或者有xml schema信息的配置,單純的logback.xml它不認(rèn)識)
然后在application.properties文件中加入:
# 配置logback logging.config=classpath:logback-spring.xml
即可。
注意如果是logging.config=classpath:xxxx/logback-spring.xml,
就不行了哈!我試過好多次!
配置的內(nèi)容基本可以參考下面的來:
<?xml version="1.0" encoding="UTF-8"?> <configuration> <!-- 屬性文件 --> <property name="processName" value="xxx"/> <property name="logDir" value="/opt/logs/xxx"/> <!-- 默認(rèn)的控制臺日志輸出,一般生產(chǎn)環(huán)境都是后臺啟動,這個沒太大作用 --> <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> <!-- 修改其他包的日志輸出級別 --> <logger name="org.apache.zookeeper"> <level value="WARN"/> </logger> <!-- root 默認(rèn)日志配置 , 注意這里的級別哈!小心生產(chǎn)環(huán)境用DEBUG,壓爆你的磁盤!--> <root level="INFO"> <appender-ref ref="logfile"/> <appender-ref ref="stdout"/> </root> </configuration>
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。