日誌是一個系統很是重要的一部分,咱們常常須要經過查看日誌來定位問題,今天咱們一塊兒來學習一下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
< OFF
。git
若是日誌設置爲ERROR
,那麼低於ERROR
級別的日誌將不會輸出。github
若是咱們想要設置某個包的日誌級別,則在pom文件中加入下面這行配置:redis
logging: level: # 包名 com.javatrip: warn
若是想修改Spring Boot默認級別,則將包名改成root
。spring
logging: level: root: warn
1.2 控制檯日誌介紹
默認狀況下,Spring Boot會將INFO
級別的日誌輸出到控制檯。控制檯輸出信息以下:數據庫
日誌輸出內容具體含義以下:緩存
- 時間日期:精確到毫秒
- 日誌級別:ERROR, WARN, INFO, DEBUG or TRACE
- 進程ID
- 分隔符:
---
標識實際日誌的開始 - 線程名:方括號括起來(可能會截斷控制檯輸出)
- Logger名:一般使用源代碼的類名
- 日誌內容
2、日誌文件輸出
在實際項目中,咱們須要將日誌輸出爲文件,以便快速定位問題。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.mybatis
這句話的意思大概就是:因爲標準的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
。
本文示例代碼已上傳至github,點個star
支持一下!
Spring Boot系列教程目錄
spring-boot-route(一)Controller接收參數的幾種方式
spring-boot-route(二)讀取配置文件的幾種方式
spring-boot-route(五)整合Swagger生成接口文檔
spring-boot-route(六)整合JApiDocs生成接口文檔
spring-boot-route(七)整合jdbcTemplate操做數據庫
spring-boot-route(八)整合mybatis操做數據庫
spring-boot-route(九)整合JPA操做數據庫
spring-boot-route(十一)數據庫配置信息加密
spring-boot-route(十二)整合redis作爲緩存
spring-boot-route(十三)整合RabbitMQ
spring-boot-route(十五)整合RocketMQ
spring-boot-route(十六)使用logback生產日誌文件
spring-boot-route(十七)使用aop記錄操做日誌
spring-boot-route(十八)spring-boot-adtuator監控應用
spring-boot-route(十九)spring-boot-admin監控服務
spring-boot-route(二十)Spring Task實現簡單定時任務
spring-boot-route(二十一)quartz實現動態定時任務
spring-boot-route(二十二)實現郵件發送功能
這個系列的文章都是工做中頻繁用到的知識,學完這個系列,應付平常開發綽綽有餘。若是還想了解其餘內容,掃面下方二維碼告訴我,我會進一步完善這個系列的文章!