springboot中l(wèi)ogback日志配置的詳細說明
在 Spring Boot 項目中,默認使用 Logback 作為日志框架。Logback 是一個高效、靈活的日志記錄工具,支持多種日志格式和輸出目標(如控制臺、文件等)。通過配置 logback-spring.xml 文件,可以自定義日志的輸出方式和格式。
以下是 Spring Boot 中 Logback 日志配置的詳細說明:
1. 創(chuàng)建或修改 logback-spring.xml
在 Spring Boot 項目中,默認會使用 logback-spring.xml 文件來配置日志。如果該文件不存在,可以在 src/main/resources 目錄下創(chuàng)建一個。
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<!-- 配置控制臺輸出 -->
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
</encoder>
</appender>
<!-- 配置文件輸出 -->
<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>logs/app.log</file>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>logs/app-%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>30</maxHistory>
</rollingPolicy>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
</encoder>
</appender>
<!-- 配置錯誤日志輸出 -->
<appender name="ERROR_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>logs/error.log</file>
<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
<level>ERROR</level>
</filter>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>logs/error-%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>30</maxHistory>
</rollingPolicy>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
</encoder>
</appender>
<!-- 根日志配置 -->
<root level="INFO">
<appender-ref ref="CONSOLE"/>
<appender-ref ref="FILE"/>
</root>
<!-- 自定義包的日志級別 -->
<logger name="com.example" level="DEBUG" additivity="false">
<appender-ref ref="CONSOLE"/>
<appender-ref ref="FILE"/>
</logger>
<!-- 配置錯誤日志 -->
<logger name="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter" level="ERROR">
<appender-ref ref="ERROR_FILE"/>
</logger>
</configuration>2. 配置說明
2.1 日志格式
通過 <encoder> 標簽可以配置日志的輸出格式。常用占位符包括:
%d{yyyy-MM-dd HH:mm:ss.SSS}:日期和時間[%thread]:線程名%-5level:日志級別(右對齊,寬度 5)%logger{36}:類名或包名(最多顯示 36 個字符)%msg:日志消息
2.2 控制臺輸出
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
配置控制臺輸出,日志會直接打印在終端。
2.3 文件輸出
<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
文件輸出支持滾動策略,按天生成日志文件:
logs/app.log:當前日志文件logs/app-yyyy-MM-dd.log:歷史日志文件
滾動策略參數(shù)說明:
<fileNamePattern>:歷史日志文件的命名規(guī)則<maxHistory>:保留 30 天的歷史日志
2.4 錯誤日志輸出
<appender name="ERROR_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
專門記錄錯誤級別的日志,通過 <filter> 標簽設置只記錄 ERROR 級別的日志。
2.5 根日志配置
<root level="INFO">
設置根日志的級別為 INFO,并將輸出目標指向控制臺和文件。
2.6 自定義包的日志級別
通過 <logger> 標簽可以為特定包或類配置不同的日志級別:
name="com.example":指定包名level="DEBUG":設置日志級別為DEBUGadditivity="false":表示不繼承父 logger 的配置
3. 配置生效條件
確保 logback-spring.xml 文件位于 src/main/resources 目錄下。如果項目中沒有該文件,Spring Boot 會使用默認日志配置。
4. 常見問題
4.1 日志文件不生成
- 檢查
<file>和<fileNamePattern>的路徑是否正確。 - 確保程序有寫入權(quán)限。
4.2 自定義包的日志不生效
- 確保
name屬性與實際類名或包名完全一致。 - 確保
additivity="false",避免繼承父 logger 的配置。
4.3 日志級別無效
- 確保
<logger>標簽中的level配置正確(如DEBUG,INFO,ERROR)。 - 確保沒有其他配置覆蓋了該日志級別。
5. 總結(jié)
通過以上配置,可以靈活地定義 Spring Boot 應用的日志輸出方式和格式??梢愿鶕?jù)實際需求調(diào)整日志級別、輸出目標和文件路徑,從而更好地監(jiān)控和調(diào)試應用。
到此這篇關(guān)于springboot中l(wèi)ogback日志配置的詳細說明的文章就介紹到這了,更多相關(guān)springboot logback日志配置內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
深入剖析Java中Map.Entry的方法與實戰(zhàn)應用
在Java集合框架中,Map.Entry扮演著連接鍵值對的橋梁角色,作為Map接口的內(nèi)部接口,它封裝了鍵值對的本質(zhì),是高效處理映射數(shù)據(jù)的核心工具,下面我我們就來深入剖析Map.Entry的概念,方法及實戰(zhàn)應用2025-06-06
SpringBoot集成RabbitMQ實現(xiàn)用戶注冊的示例代碼
這篇文章主要介紹了SpringBoot集成RabbitMQ實現(xiàn)用戶注冊的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-12-12
使用IntelliJ IDEA調(diào)式Stream流的方法步驟
本文主要介紹了使用IntelliJ IDEA調(diào)式Stream流的方法步驟,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-05-05
Spring中的@RestControllerAdvice注解使用方法解析
這篇文章主要介紹了Spring中的@RestControllerAdvice注解使用方法解析,@RestControllerAdvice是Controller的增強 常用于全局異常的捕獲處理 和請求參數(shù)的增強,需要的朋友可以參考下2024-01-01
Freemaker Replace函數(shù)的正則表達式運用
這篇文章主要介紹了Freemaker Replace函數(shù)的正則表達式運用 的相關(guān)資料,需要的朋友可以參考下2015-12-12
springboot啟動過程中常用的回調(diào)示例詳解
springboot提供非常豐富回調(diào)接口,利用這些接口可以做非常多的事情,本文通過實例代碼給大家介紹springboot啟動過程中常用的回調(diào)知識感興趣的朋友跟隨小編一起看看吧2022-01-01
maven父子工程多模塊統(tǒng)一管理版本號的解決方法
maven父子工程多模塊,每個模塊還都可以獨立存在,子模塊往往通常希望和父工程保持一樣的版本,如果每個工程單獨定義版本號,后期變更打包也非常麻煩,,所以本文給大家介紹了maven父子工程多模塊如何管理統(tǒng)一的版本號,需要的朋友可以參考下2024-09-09
關(guān)于IDEA中spring-cloud-starter-alibaba-nacos-discovery 無法引入問題
這篇文章主要介紹了關(guān)于IDEA中spring-cloud-starter-alibaba-nacos-discovery 無法引入問題,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-02-02

