基於Spring Boot的Logback日志輪轉配置


在生產環境下,日志是最好的問題調試和跟蹤方法,因此日志的地位是十分重要的。我們平時經常使用的log4j,slf4j,logback等等,他們的配置上大同小異。這里就結合Spring Boot配置一下Logback的日志。

默認最簡單的配置

默認情況下,如果對日志沒有特殊處理,可以直接基於application.properties進行配置。

常用的參數有:

logging.level

配置日志的級別

logging.file
logging.path

這兩個參數只能配置一個生效,一個是文件(可以有絕對路徑或者相對路徑);另一個是路徑,文件的名稱會默認為spring.log

日志默認按照大小進行切分,由於我這邊沒有產生那么大的文件,因此沒有做實驗。

這種方法最簡單,但是不能處理那種復雜的日志輪轉的機制。比如沒天一個文件這種需求,因此可以考慮使用獨立的日志文件進行配置:

使用獨立的配置文件配置

如果有復雜的需求,可以像其他普通的web應用一樣,配置獨立的logback.xml:

  • 首先注意的是這個文件必須放在resources目錄下(我這邊發現,如果通過logging.config指向另一個目錄下的logback.xml會在程序啟動時報錯,報無法解析該xml。猜想可能是在其他目錄下的xml都被當做spring的配置或者有xml schema信息的配置,單純的logback.xml它不認識)

然后在application.properties文件中加入:

# 配置logback
logging.config=classpath:logback-spring.xml

即可。

注意如果是logging.config=classpath:xxxx/logback-spring.xml,就不行了哈!我試過好多次!

配置的內容基本可以參考下面的來:

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <!-- 屬性文件 -->
    <property name="processName" value="xxx"/>
    <property name="logDir" value="/opt/logs/xxx"/>

    <!-- 默認的控制台日志輸出,一般生產環境都是后台啟動,這個沒太大作用 -->
    <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>

    <!-- 配置文件輪轉 -->
    <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 默認日志配置 , 注意這里的級別哈!小心生產環境用DEBUG,壓爆你的磁盤!-->
    <root level="INFO">
        <appender-ref ref="logfile"/>
        <appender-ref ref="stdout"/>
    </root>
</configuration>

參考


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM