spring-boot-route(十六)使用logback生產日誌文件

日誌是一個系統很是重要的一部分,咱們常常須要經過查看日誌來定位問題,今天咱們一塊兒來學習一下Spring Boot的日誌系統。有不少同窗習慣性的在生產代碼中使用System.out來輸出日誌,這是不推薦的一種作法,由於System.out是一個同步操做,會在必定程度上影響系統性能,而Logger是一個異步操做。html

Spring Boot默認的日誌系統是logback,固然咱們並不須要去引用logback的依賴,由於在spring-boot-starter中已經應用了logback的依賴。java

1、控制檯日誌信息介紹

1.1 日誌級別

日誌級別從高到低爲:TRACE < DEBUG < INFO < WARN < ERROR < ALL < OFFgit

若是日誌設置爲ERROR,那麼低於ERROR級別的日誌將不會輸出。github

若是咱們想要設置某個包的日誌級別,則在pom文件中加入下面這行配置:spring

logging:
  level:
      # 包名
    com.javatrip: warn

若是想修改Spring Boot默認級別,則將包名改成root微信

logging:
  level:
    root: warn

1.2 控制檯日誌介紹

默認狀況下,Spring Boot會將INFO級別的日誌輸出到控制檯。控制檯輸出信息以下:app

日誌輸出內容具體含義以下:異步

  • 時間日期:精確到毫秒
  • 日誌級別:ERROR, WARN, INFO, DEBUG or TRACE
  • 進程ID
  • 分隔符:--- 標識實際日誌的開始
  • 線程名:方括號括起來(可能會截斷控制檯輸出)
  • Logger名:一般使用源代碼的類名
  • 日誌內容

2、日誌文件輸出

在實際項目中,咱們須要將日誌輸出爲文件,以便快速定位問題。Spring Boot關於日誌文件的信息能夠參考官網https://docs.spring.io/spring-boot/docs/current/reference/htmlsingle/#boot-features-loggingspring-boot

Because the standard logback.xml configuration file is loaded too early, you cannot use extensions in it. You need to either use logback-spring.xml or define a logging.config property.

這句話的意思大概就是:因爲標準的logback.xml配置文件加載得太早,所以您不能在其中使用擴展名。您須要使用logback-spring.xml或定義logging.config屬性。性能

所以咱們來定義一個logback-spring.xml的文件來進行日誌信息的配置。

logback-spring.xml文件定義及註釋:

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <!-- 日誌文件名 -->
    <property name="LOG_FILE" value="myLog" />
    <!-- 日誌文件路徑 -->
    <property name="LOG_PATH" value="D://log//dev" />
    <!-- 控制檯日誌輸出格式 -->
    <property name="LOG_PATTERN_CONSOLE" value="%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{50} --> %msg%n" />
    <!-- 文件日誌輸出格式 -->
    <property name="LOG_PATTERN_FILE" value="%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{50} --> %msg%n" />
    <!--- 設置控制檯日誌 -->
    <appender name="consoleLog" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>${LOG_PATTERN_CONSOLE}</pattern>
        </encoder>
    </appender>
    <!-- 設置日誌文件 -->
    <appender name="fileLog" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <encoder>
            <pattern>${LOG_PATTERN_FILE}</pattern>
        </encoder>
        <!-- 總文件日誌 -->
        <file>${LOG_PATH}/${LOG_FILE}.log</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!-- 天天的文件日誌 -->
            <fileNamePattern>${LOG_PATH}/${LOG_FILE}-%d{yyyy-MM-dd}.log</fileNamePattern>
            <!-- 日誌文件保存7天,超過7天的自動刪除 -->
            <maxHistory>7</maxHistory>
        </rollingPolicy>
    </appender>

    <!-- 設置日誌級別,及須要記錄日誌的類 -->
    <root level="INFO">
        <appender-ref ref="consoleLog" />
        <appender-ref ref="fileLog" />
    </root>
</configuration>

啓動項目後,在D:\log\dev中會生產咱們的日誌文件myLog.log,加入咱們系統一直運行,則在咱們的文件目錄下會生成一個myLog.log文件和7個最近日誌的文件myLog-某年-某月-某日.log

此是spring-boot-route系列的第十六篇文章,這個系列的文章都比較簡單,主要目的就是爲了幫助初次接觸Spring Boot 的同窗有一個系統的認識。本文已收錄至個人github,歡迎各位小夥伴star

githubhttps://github.com/binzh303/s...

點關注、不迷路

若是以爲文章不錯,歡迎關注點贊收藏,大家的支持是我創做的動力,感謝你們。

若是文章寫的有問題,請不要吝嗇,歡迎留言指出,我會及時覈查修改。

若是你還想更加深刻的瞭解我,能夠微信搜索「Java旅途」進行關注。回覆「1024」便可得到學習視頻及精美電子書。天天7:30準時推送技術文章,讓你的上班路不在孤獨,並且每個月還有送書活動,助你提高硬實力!

相關文章
相關標籤/搜索