詳解Spring Boot配置使用Logback進行日志記錄的實戰(zhàn)
spring Boot實戰(zhàn)之配置使用Logback進行日志記錄 ,分享給大家
在這篇文章中我們將討論在Spring Boot中使用Logback,在Spring Boot中使用Logback很簡單
1、為了測試我們新建兩個類
package com.xiaofangtech.sunt.controller; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import com.xiaofangtech.sunt.helper.LogHelper; @RestController @RequestMapping("log") public class LogController { private final Logger logger = LoggerFactory.getLogger(this.getClass()); @RequestMapping("writelog") public Object writeLog() { logger.debug("This is a debug message"); logger.info("This is an info message"); logger.warn("This is a warn message"); logger.error("This is an error message"); new LogHelper().helpMethod(); return "OK"; } }
package com.xiaofangtech.sunt.helper; import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class LogHelper { private final Logger logger = LoggerFactory.getLogger(this.getClass()); public void helpMethod(){ logger.debug("This is a debug message"); logger.info("This is an info message"); logger.warn("This is a warn message"); logger.error("This is an error message"); } }
2、運行,在瀏覽器中輸入http://localhost:8080/log/writelog 將會看到以下結(jié)果
我們沒有配置任何其它配置,就可以看到來自logback root logger的輸出信息。雖然默認情況下logback是會打印debug級別的日志,但是我們注意到debug級別的日志沒有記錄下來,那是因為Spring Boot為Logback提供了默認的配置文件,base.xml,另外Spring Boot 提供了兩個輸出端的配置文件console-appender.xml和file-appender.xml,base.xml引用了這兩個配置文件。
以下是base.xml的內(nèi)容,我們可以看到,root logger的日志級別被重寫為Info級別,這就是上面例子中debug級別的日志沒有打印的原因
<?xml version="1.0" encoding="UTF-8"?> <!-- Base logback configuration provided for compatibility with Spring Boot 1.1 --> <included> <include resource="org/springframework/boot/logging/logback/defaults.xml" /> <property name="LOG_FILE" value="${LOG_FILE:-${LOG_PATH:-${LOG_TEMP:-${java.io.tmpdir:-/tmp}}/}spring.log}"/> <include resource="org/springframework/boot/logging/logback/console-appender.xml" /> <include resource="org/springframework/boot/logging/logback/file-appender.xml" /> <root level="INFO"> <appender-ref ref="CONSOLE" /> <appender-ref ref="FILE" /> </root> </included>
3、通過application.properties文件對Logback進行配置
logging.file=log.log logging.level.com.xiaofangtech.sunt.controller = debug logging.level.com.xiaofangtech.sunt.helper = warn
配置記錄日志到log.log,com.xiaofangtech.sunt.controller日志級別為debug,.com.xiaofangtech.sunt.helper中日志級別為warn
我們將會看到以下結(jié)果,按照配置的日志級別進行記錄。
并且可以看到日志記錄到了日志文件中
4、通過額外的文件配置Logback
通過application.properties文件配置Logback,對于大多數(shù)Spring Boot應用來說已經(jīng)足夠了,但是對于一些大型的企業(yè)應用來說似乎有一些相對復雜的日志需求。在Spring Boot中你可以在logback.xml或者在logback-spring.xml中對Logback進行配置,相對于logback.xml,logback-spring.xml更加被偏愛。下面我們以logback-spring.xml為例。
新建logback-spring.xml,配置輸出的日志都為warn級別
<?xml version="1.0" encoding="UTF-8"?> <configuration> <include resource="org/springframework/boot/logging/logback/base.xml"/> <logger name="com.xiaofangtech.sunt.controller" level="WARN" additivity="false"> <appender-ref ref="CONSOLE"/> <appender-ref ref="FILE"/> </logger> <logger name="com.xiaofangtech.sunt.helper" level="WARN" additivity="false"> <appender-ref ref="CONSOLE"/> <appender-ref ref="FILE"/> </logger> </configuration>
運行結(jié)果如下:
本文參考:https://springframework.guru/using-logback-spring-boot/
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- IDEA?設置?SpringBoot?logback?彩色日志的解決方法?附配置文件
- Springboot使用Logback實現(xiàn)日志配置與異常記錄
- SpringBoot項目的logback日志配置(包括打印mybatis的sql語句)
- Spring Boot日志技術logback原理及配置解析
- springboot配置logback日志管理過程詳解
- 基于logback 實現(xiàn)springboot超級詳細的日志配置
- spring boot使用logback實現(xiàn)多環(huán)境日志配置詳解
- 詳解Spring Boot 使用slf4j+logback記錄日志配置
- 如何為?Spring?Boot?項目配置?Logback?日志
相關文章
使用IDEA配置Tomcat和連接MySQL數(shù)據(jù)庫(JDBC)詳細步驟
這篇文章主要介紹了使用IDEA配置Tomcat和連接MySQL數(shù)據(jù)庫(JDBC)詳細步驟,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-12-12Spring session實現(xiàn)Session共享
本文主要介紹了Spring session實現(xiàn)Session共享,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-04-04Java數(shù)據(jù)結(jié)構(gòu)之堆(優(yōu)先隊列)的實現(xiàn)
堆(優(yōu)先隊列)是一種典型的數(shù)據(jù)結(jié)構(gòu),其形狀是一棵完全二叉樹,一般用于求解topk問題。本文將利用Java語言實現(xiàn)堆,感興趣的可以學習一下2022-05-05