Java 有不少日誌系統,例如,Java Util Logging, Log4J, Log4J2, Logback 等。Spring Boot 也提供了不一樣的選項,好比日誌框架能夠用 logback 或 log4j 等。
原文地址:Spring Boot 揭祕與實戰(三) 日誌框架篇 - 如何快速集成日誌系統
博客地址:blog.720ui.com/javascript
例如,maven 依賴中添加了 spring-boot-starter-logging。java
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</dependency>複製代碼
那麼, Spring Boot 應用將自動使用 logback 做爲應用日誌框架, Spring Boot 啓動的時候,由 org.springframework.boot.logging.Logging.Logging-Application-Listener 根據狀況初始化並使用。git
值得注意的是,默認狀況下,Spring Boot 使用 logback 做爲應用日誌框架。由於 spring-boot-starter 其中包含了 spring-boot-starter-logging,該依賴內容就是 Spring Boot 默認的日誌框架 logback。github
默認狀況下,Spring Boot 配置 ERROR, WARN, INFO 三種日誌級別。若是須要 Debug 級別的日誌。在 src/main/resources/application.properties 中配置數據源信息。web
debug=true複製代碼
此外,配置 logging.level.* 來具體輸出哪些包的日誌級別。spring
例如springboot
logging.level.root=INFO
logging.level.org.springframework.web=DEBUG複製代碼
默認狀況下, Spring Boot 日誌只會輸出到控制檯,並不會寫入到日誌文件,所以,對於正式環境的應用,咱們須要經過在 application.properites 文件中配置 logging.file 文件名稱和 logging.path 文件路徑,將日誌輸出到日誌文件中。微信
logging.path = /var/tmp
logging.file = xxx.log
logging.level.root = info複製代碼
若是隻配置 logging.path,在 /var/tmp文件夾生成一個日誌文件爲 spring.log。若是隻配置 logging.file,會在項目的當前路徑下生成一個 xxx.log 日誌文件。app
值得注意的是,日誌文件會在 10MB 大小的時候被截斷,產生新的日誌文件。框架
若是,咱們但願使用 log4j 或者 log4j2,咱們能夠採用相似的方式將它們對應的依賴模塊加到 Maven 依賴中。
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-log4j</artifactId>
</dependency>複製代碼
或者
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-log4j2</artifactId>
</dependency>複製代碼
log4j 依賴模塊加到 Maven 依賴中後,在 src/main/resources 目錄下加入 log4j-spring.properties 配置文件。Spring Boot 官方推薦優先使用帶有 –spring 的文件名做爲你的日誌配置, 例如 log4j-spring.properties,固然使用 log4j.properties 也是支持的。
如今,咱們就可使用 log4j 日誌進行配置使用。log4j 配置細節就不展開講解了,對於更多log4j的用法,能夠參考相關文獻。
相關示例完整代碼: springboot-action
(完)
更多精彩文章,盡在「服務端思惟」微信公衆號!