欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Spring Boot 日志級別及配置詳解

 更新時間:2025年07月07日 09:12:53   作者:el psy congroo  
本文講解SpringBoot日志核心:通過slf4j記錄日志,支持多級別(INFO/DEBUG/TRACE)及配置輸出格式、路徑、分割策略,便于問題定位和數(shù)據(jù)分析,同時結(jié)合Lombok簡化日志代碼,強調(diào)日志持久化與安全審計的重要性,感興趣的朋友一起看看吧

為什么要學(xué)習(xí)日志

最主要的原因就是發(fā)現(xiàn)和定位問題,或者根據(jù)日志來分析程序的運行過程。隨著項目的復(fù)雜度提升,我們對日志的打印也有了更高的需求,而不僅僅是定位排查問題

比如需要記錄一些用戶的操作記錄(一些審計公司會要求),也可能需要使用日志來記錄用戶的一些喜好,把日志持久化,方便后續(xù)進行數(shù)據(jù)分析等。也可以通過日志記錄這個系統(tǒng)的運行狀態(tài),每一個方法的響應(yīng)時間,響應(yīng)狀態(tài)等,設(shè)置不同的規(guī)則,超過閾值時進行報警

還有一些內(nèi)部的違規(guī)和信息泄漏(比如客戶信息被賣掉)現(xiàn)象出現(xiàn)后,如果未記錄留存日志,為事后調(diào)查提供依據(jù),那么后續(xù)很難追查(一些公司查看客戶信息的操作都會記錄日志,如果頻繁查詢也會報警)

日志使用

SpringBoot 內(nèi)置了日志框架 slf4j,我們可以直接調(diào)用 slf4j 來輸出日志

打印日志的步驟:

  1. 在程序中得到日志對象
  2. 使用日志對象輸出要打印的內(nèi)容

獲取日志對象需要使用 LoggerFactory,如下代碼所示:

private static final Logger logger = LoggerFactory.getLogger(XXX.class);

LoggerFactory.getLogger 需要傳遞一個參數(shù),標識這個日志的名稱。這樣可以更清晰地知道是哪個類輸出的日志。當有問題時,可以更方便直觀地定位到問題類

注意 Logger 是屬于 org.slf4j 包下的,不要導(dǎo)錯包

我們先使用 info () 方法來輸出日志,如下代碼所示:

import jakarta.annotation.PostConstruct;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class LogController {
    private static final Logger logger = LoggerFactory.getLogger(LogController.class);
    @PostConstruct
    public void logger() {
        System.out.println("打印日志");
        logger.info("打印日志");
    }
}

打印日志效果展示:

可以看到 System.out.println 打印的日志,比 slf4j 打印的日志少了很多信息

日志級別

日志級別代表著日志信息對應(yīng)問題的嚴重性, 為了更快地篩選符合目標的日志信息

日志級別的分類

日志的級別從高到低依次為: FATAL、ERROR、WARN、INFO、DEBUG、TRACE

  1. FATAL:致命信息,表示需要立即被處理的系統(tǒng)級錯誤
  2. ERROR:錯誤信息,不影響系統(tǒng)的繼續(xù)運行
  3. WARN:警告信息,不影響使用,但需要注意的問題
  4. INFO:普通信息,用于記錄應(yīng)用程序正常運行時的一些信息,例如系統(tǒng)啟動完成、請求處理完成等
  5. DEBUG:調(diào)試信息,需要調(diào)試時候的關(guān)鍵信息打印
  6. TRACE:追蹤信息,比 DEBUG 更細粒度的信息事件 (除非有特殊用意,否則請使用 DEBUG 級別替代)

日志級別是開發(fā)人員自己設(shè)置的,根據(jù)開發(fā)人員自己的理解來判斷該信息的重要程度,和測試人員的 Bug 級別沒有關(guān)系

日志級別的使用

針對這些級別,Logger 對象分別提供了對應(yīng)的方法來輸出日志(除了fatal)

Spring Boot 默認集成的日志框架是 Logback。同時,Spring Boot 在日志方面還整合了 SLF4J(Simple Logging Facade for Java),SLF4J 并不是一個具體的日志實現(xiàn)框架,而是一個抽象的日志門面

SLF4J 提供了一套通用的接口規(guī)范,允許開發(fā)者在不修改應(yīng)用代碼中日志調(diào)用方式的前提下,靈活切換底層實際的日志實現(xiàn)框架,比如 Logback、Log4j 等。這就使得應(yīng)用程序在不同的部署環(huán)境或基于不同的需求,可以輕松地更換日志實現(xiàn),而無需大規(guī)模改動代碼

在 Logback 中,雖然沒有獨立的 FATAL 日志級別,但由于 SLF4J 的存在,它可以將 SLF4J 定義的 FATAL 級別進行映射處理。具體來說,Logback 把 SLF4J 中的 FATAL 級別映射到了 ERROR 級別。這意味著,即使通過其他方式調(diào)用 FATAL ,最終也會被映射為 ERROR 級別

通過這種映射機制,即使 Logback 自身沒有專門的 FATAL 級別,但依然能夠和基于 SLF4J 的日志體系很好地兼容

@RestController
public class LogController {
    private static final Logger logger = LoggerFactory.getLogger(LogController.class);
    @PostConstruct
    public void printLog() {
        logger.error("error日志");
        logger.warn("warn日志");
        logger.info("info日志");
        logger.debug("debug日志");
        logger.trace("trace日志");
    }
}

發(fā)現(xiàn)只打印了error , warn 和 info 級別的日志。因為日志的輸出級別默認是 info ,如果不進行任何配置,那么低于INFO級別的日志就不會打印

日志配置

配置日志級別

yml 配置

logging:
  level:
    root: debug

這樣會將 所有包(包括 Spring 框架內(nèi)部) 的日志級別都設(shè)置為 DEBUG,導(dǎo)致控制臺輸出大量框架層面的調(diào)試信息,影響排查效率

將 root 替換為自己代碼中需要打印 DEBUG 日志的包路徑,這樣僅會啟用指定包下的 DEBUG 日志,而 Spring 等其他依賴仍使用默認級別(通常是 INFO)

如果需要對不同包設(shè)置不同級別,可以這樣配置:

logging:
  level:
    # 自定義業(yè)務(wù)包開啟 DEBUG 級別日志
    org.example.j20250702: debug
    # Spring 框架內(nèi)部日志,只打印 INFO 及更高級別
    org.springframework: info

配置日志持久化

以上的日志都是輸出在控制臺上的,然而我們常常需要把日志保存下來,以便出現(xiàn)問題之后追溯問題。把日志保存下來就叫持久化

日志持久化有兩種方式

  1. 配置日志文件的路徑和文件名:

yml 配置

logging:
  file:
    name: logger/springboot.log

后面可以跟絕對路徑或者相對路徑

運行結(jié)果顯示,日志內(nèi)容保存在了對應(yīng)的目錄下

  1. 配置日志文件的保存路徑:

yml 配置

logging:
  file:
    path: log

后面可以跟絕對路徑或者相對路徑,但只能設(shè)置日志的路徑,文件名固定為 spring.log

運行程序,該路徑下多出一個日志文件: spring.log

logging.file.name 和 logging.file.path 兩個都配置路徑的情況下,只生效其一,以 logging.file.name 為準

配置日志文件分割

如果我們的日志都放在一個文件中,隨著項目的運行,日志文件會越來越大,所以有必要對日志文件進行分割

當然,日志框架也考慮到了這一點,所以如果不進行配置,默認日志文件超過 10MB 就進行分割

配置項說明默認值
logging.logback.rollingpolicy.file-name-pattern日志分割后的文件名格式${LOG_FILE}.%d{yyyy-MM-dd}.%i.gz
logging.logback.rollingpolicy.max-file-size日志文件超過這個大小就自動分割10MB

yml配置日志文件分割:

logging:
  logback:
    rollingpolicy:
      file-name-pattern: ${LOG_FILE}.%d{yyyy-MM-dd}.%i
      max-file-size: 1KB
  file:
    path: log
  • 日志文件超過 1KB 就分割 (設(shè)置 1KB 是為了更好展示文件分割)
  • 分割后的日志文件名為:日志名.日期.編號(每日重置)

配置日志打印格式

目前日志打印的格式是默認的,我們可以進行配置,而且支持控制臺和日志文件分別設(shè)置

配置項默認值
logging.pattern.console
(控制臺日志格式)
%clr(%d{${LOG_DATEFORMAT_PATTERN:-yyyy-MM-dd'T'HH:mm:ss.SSSXXX}}){faint} %clr(${LOG_LEVEL_PATTERN:-%5p}) %clr(${PID:- }){magenta} %clr(---){faint} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}
logging.pattern.file
(日志文件的日志格式)
%d{${LOG_DATEFORMAT_PATTERN:-yyyy-MM-dd'T'HH:mm:ss.SSSXXX}} ${LOG_LEVEL_PATTERN:-%5p} ${PID:- } --- [%t] %-40.40logger{39} : %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}

格式說明:

  1. %clr(表達式){顏色} :設(shè)置輸入日志的顏色,支持顏色有以下幾種:blue、cyan、faint、green、magenta、red、yellow

  2. %d{${LOG_DATEFORMAT_PATTERN:-yyyy-MM-dd'T'HH:mm:ss.SSSXXX}} 日期和時間 —— 精確到毫秒

%d{}: 日期

${LOG_DATEFORMAT_PATTERN:-yyyy-MM-dd'T'HH:mm:ss.SSSXXX} :非空表達式,獲取系統(tǒng)屬性 LOG_DATEFORMAT_PATTERN , 若不存在,則使用 yyyy-MM-dd HH:mm:ss.SSSXXX 格式,系統(tǒng)屬性可以通過System.getProperty("LOG_DATEFORMAT_PATTERN") 獲取

  1. %p 顯示日志級別 ERROR,WARN,INFO,DEBUG,TRACE。
    %t 線程名。
    %c 類的全限定名。
    %M 方法名。
    %L 行號。
    %m 或者 %msg 顯示輸出消息。
    %n 換行符。
  2. %5 表示如果字符長度小于 5,則右邊用空格填充。
    %-5 表示如果字符長度小于 5,則左邊用空格填充。
    %.15 表示如果字符長度超過 15,截去多余字符。
    %15.15 表示如果字符長度小于 15,則右邊用空格填充;若字符長度超過 15,截去多余字符。

更多說明,參考:https://logback.qos.ch/manual/layouts.html#conversionWord

yml配置

logging:
  pattern:
    console: '%d{yyyy-MM-dd HH:mm:ss.SSS} %p %c %M %L [%t] %m%n'
    file: '%d{yyyy-MM-dd HH:mm:ss.SSS} %p %c %M %L [%t] %m%n'

項目運行, 觀察日志變化:

通常情況下,咱們就使用默認的日志打印格式即可

設(shè)置了顏色,卻沒有生效?

需要配置,讓 idea 支持控制臺顏色顯示。打開啟動配置,添加 VM options

在 VM options 中添加 -Dspring.output.ansi.enabled=ALWAYS

應(yīng)用并重啟程序

使用lombok提供的注解

每個類都添加一遍LoggerFactory.getLogger(xxx.class) 很繁瑣,lombok 給我們提供了一種更簡單的方式

  1. 添加 lombok 框架支持
  2. 使用 @slf4j 注解輸出日志
<dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <optional>true</optional>
</dependency>

lombok 提供的 @Slf4j 會提供一個日志對象 log, 我們直接使用就可以

import jakarta.annotation.PostConstruct;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.RestController;
@Slf4j
@RestController
public class LogController {
    @PostConstruct
    public void logger() {
        log.info("打印日志");
    }
}

idea反編譯的字節(jié)碼是這樣的

到此這篇關(guān)于Spring Boot 日志的文章就介紹到這了,更多相關(guān)Spring Boot 日志內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • SpringBoot實現(xiàn)密碼安全存儲的五種方式小結(jié)

    SpringBoot實現(xiàn)密碼安全存儲的五種方式小結(jié)

    項目開發(fā)中,密碼安全存儲是非常關(guān)鍵的一環(huán),作為開發(fā)者,我們需要確保用戶的密碼在存儲時被安全地加密,避免因數(shù)據(jù)泄露而造成嚴重后果,所以本文給大家介紹了SpringBoot實現(xiàn)密碼安全存儲的5種方式,需要的朋友可以參考下
    2025-03-03
  • springmvc使用@notNull注解驗證請求參數(shù)方式

    springmvc使用@notNull注解驗證請求參數(shù)方式

    這篇文章主要介紹了springmvc使用@notNull注解驗證請求參數(shù)方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教<BR>
    2024-01-01
  • 使用springboot時,解決@Scheduled定時器遇到的問題

    使用springboot時,解決@Scheduled定時器遇到的問題

    這篇文章主要介紹了使用springboot時,解決@Scheduled定時器遇到的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • Spring?boot整合jsp和tiles模板示例

    Spring?boot整合jsp和tiles模板示例

    這篇文章主要介紹了Spring?boot整合jsp模板和tiles模板的示例演示過程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-03-03
  • Springboot?JPA級聯(lián)操作的實現(xiàn)(一對一、一對多、多對多)

    Springboot?JPA級聯(lián)操作的實現(xiàn)(一對一、一對多、多對多)

    本文深入解析JPA中的一對一、一對多和多對多級聯(lián)操作,包括實體間的關(guān)系建立、查詢、保存、刷新和刪除等操作,具有一定的參考價值,感興趣的可以了解一下
    2025-07-07
  • java實現(xiàn)MD5加密算法的實例代碼

    java實現(xiàn)MD5加密算法的實例代碼

    這篇文章主要介紹了java實現(xiàn)MD5加密算法的實例代碼,有需要的朋友可以參考一下
    2013-12-12
  • 詳解Java關(guān)鍵字final

    詳解Java關(guān)鍵字final

    今天帶大家學(xué)習(xí)Java基礎(chǔ)知識,文中對關(guān)鍵字final作了非常詳細的介紹,對正在學(xué)習(xí)Java的小伙伴們很有幫助,需要的朋友可以參考下
    2021-05-05
  • 分享Java常用開發(fā)編輯器工具

    分享Java常用開發(fā)編輯器工具

    這篇文章主要給大家分享了分享Java常用開發(fā)編輯器工具,文章內(nèi)容介紹非常詳細,具有很大的參考價值,需要的小伙伴可以參考一下,希望對你的工作或?qū)W習(xí)有一定的幫助
    2022-03-03
  • Java8新特性之線程安全日期類

    Java8新特性之線程安全日期類

    這篇文章主要介紹了Java8新特性之線程安全日期類,文中有非常詳細的代碼示例,對正在學(xué)習(xí)java的小伙伴們有一定的幫助,需要的朋友可以參考下
    2021-04-04
  • Java生成訂單號或唯一id的高并發(fā)方案(4種方法)

    Java生成訂單號或唯一id的高并發(fā)方案(4種方法)

    本文主要介紹了Java生成訂單號或唯一id的高并發(fā)方案,包括4種方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-01-01

最新評論