日誌是一個系統非常重要的一部分,我們經常需要通過檢視日誌來定位問題,今天我們一起來學習一下Spring Boot的日誌系統。有很多同學習慣性的在生產程式碼中使用System.out來輸出日誌,這是不推薦的一種做法,因為System.out是一個同步操作,會在一定程度上影響系統效能,而Logger是一個非同步操作。
Spring Boot預設的日誌系統是logback
,當然我們並不需要去引用logback
的依賴,因為在spring-boot-starter
中已經應用了logback
的依賴。
一、控制檯日誌資訊介紹
1.1 日誌級別
日誌級別從高到低為:TRACE
< DEBUG
< INFO
< WARN
< ERROR
< ALL
< OFF
。
如果日誌設定為ERROR
,那麼低於ERROR
級別的日誌將不會輸出。
如果我們想要設定某個包的日誌級別,則在pom檔案中加入下面這行配置:
logging:
level:
# 包名
com.javatrip: warn
如果想修改Spring Boot預設級別,則將包名改為root
。
logging:
level:
root: warn
1.2 控制檯日誌介紹
預設情況下,Spring Boot會將INFO
級別的日誌輸出到控制檯。控制檯輸出資訊如下:
日誌輸出內容具體含義如下:
- 時間日期:精確到毫秒
- 日誌級別:ERROR, WARN, INFO, DEBUG or TRACE
- 程式ID
- 分隔符:
---
標識實際日誌的開始 - 執行緒名:方括號括起來(可能會截斷控制檯輸出)
- Logger名:通常使用原始碼的類名
- 日誌內容
二、日誌檔案輸出
在實際專案中,我們需要將日誌輸出為檔案,以便快速定位問題。Spring Boot關於日誌檔案的資訊可以參考官網https://docs.spring.io/spring-boot/docs/current/reference/htmlsingle/#boot-features-logging
。
Because the standard
logback.xml
configuration file is loaded too early, you cannot use extensions in it. You need to either uselogback-spring.xml
or define alogging.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
!
github:https://github.com/binzh303/spring-boot-route
點關注、不迷路
如果覺得文章不錯,歡迎關注、點贊、收藏,你們的支援是我創作的動力,感謝大家。
如果文章寫的有問題,請不要吝嗇,歡迎留言指出,我會及時核查修改。
如果你還想更加深入的瞭解我,可以微信搜尋「Java旅途」進行關注。回覆「1024」即可獲得學習視訊及精美電子書。每天7:30準時推送技術文章,讓你的上班路不在孤獨,而且每月還有送書活動,助你提升硬實力!