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

Spring Boot日志的打印與持久化詳細(xì)解析

 更新時(shí)間:2022年07月19日 10:23:48   作者:偷偷敲代碼的青花瓷  
Spring Boot默認(rèn)使用SLF4J+Logback 記錄日志,并提供了默認(rèn)配置,即使我們不進(jìn)行任何額外配,也可以使用SLF4J+Logback進(jìn)行日志輸出

1. 日志有什么用

日志是程序的重要組成部分,想象一下,如果程序報(bào)錯(cuò)了,不讓你打開控制臺(tái)看日志,那么你能找到報(bào)錯(cuò)的原因嗎?

答案是否定的,寫程序不是買彩票,不能完全靠猜,因此日志對(duì)應(yīng)我們來說,最重要的用途就是排除和定位問題。

除了發(fā)現(xiàn)和定位問題之外,我們還可以通過日志實(shí)現(xiàn)以下功能:

  • 記錄用戶登錄日志,方便分析用戶正常登錄還是惡意破解用戶
  • 記錄系統(tǒng)的操作日志,方便數(shù)據(jù)恢復(fù)和定位操作人
  • 記錄程序的執(zhí)行實(shí)現(xiàn),方便以后優(yōu)化程序提供數(shù)據(jù)支持

2. 日志怎么用

Spring Boot 項(xiàng)目在啟動(dòng)的時(shí)候默認(rèn)就有日志輸出,如下圖所示:

以上內(nèi)容就是 Spring Boot 輸出的控制臺(tái)日志信息。

通過上述日志信息我們可以發(fā)現(xiàn)以下3個(gè)問題:

  • Spring Boot 內(nèi)置了日志框架(不然也輸出不了日志)
  • 默認(rèn)情況下,輸出的?志并?是開發(fā)者定義和打印的,那開發(fā)者怎么在程序中?定義打印?志呢?
  • ?志默認(rèn)是打印在控制臺(tái)上的,?控制臺(tái)的?志是不能被保存的,那么怎么把?志永久的保存下來 呢?

下面我們一起來找尋這些問題的答案。

3. Spring Boot 自定義日志的打印

  • 在一個(gè)類中先獲取到打印日志對(duì)象(日志框架提供的日志對(duì)象,而日志框架默認(rèn)已經(jīng)集成到 Spring Boot 里了)
  • 使用日志對(duì)象提供的方法實(shí)現(xiàn)日志的打印

3.1 先獲取到打印日志對(duì)象

在程序中獲取日志對(duì)象需要使用日志工廠 LoggerFactory,如下代碼所示:

 // 1.先得到日志對(duì)象(來自 slf4j)
    private static final Logger log =
            LoggerFactory.getLogger(UserController.class);

日志工廠需要將每個(gè)類的類型傳遞進(jìn)去,這樣我們才知道日志的歸屬類,才能更方便,更直觀的定位到問題類。

注意:Logger 對(duì)象是屬于 org.slf4j 包下的,不要導(dǎo)入錯(cuò)誤。

因?yàn)?Spring Boot 中內(nèi)置了日志框架 slf4j,所以 咋們可以直接在程序中調(diào)用 slf4j 來輸出日志

3.2 使用日志對(duì)象打印日志

日志對(duì)象的打印方法有很多,我們可以先使用 info() 方法來輸出日志,如下代碼所示:

// 2.使用日志對(duì)象提供的打印方法進(jìn)行日志打印
        log.trace("我是 trace");
        log.debug("我是 debug");
        log.info("我是 info");
        log.warn("我是 warn");
        log.error("我是 error");

打印效果展示:

3.3 日志格式說明

4. 日志級(jí)別

5. 日志持久化(將日志永久的保存到磁盤的某個(gè)位置)

以上的?志都是輸出在控制臺(tái)上的,然?在?產(chǎn)環(huán)境上咱們需要將?志保存下來,以便出現(xiàn)問題之后追 溯問題,把?志保存下來的過程就叫做持久化。

想要將?志進(jìn)?持久化,只需要在配置?件中指定?志的存儲(chǔ)?錄或者是指定?志保存?件名之后, Spring Boot 就會(huì)將控制臺(tái)的?志寫到相應(yīng)的?錄或?件下了。

設(shè)置日志的保存路徑

在配置文件中,輸入如下代碼:

# 設(shè)置日志的保存路徑
# 正確設(shè)置日志路徑的方式1
logging.file.path=D:/JavaCode/
# 正確設(shè)置日志路徑的方式2
logging.file.path=D:\\JavaCode\\

保存后:

注意:

logging.file.path=D:\JavaCode\

這種寫法,Spring Boot 會(huì)認(rèn)為是一個(gè)特殊字符,而非目錄,所以日志持久化不會(huì)成功。

6. 更簡(jiǎn)單的日志輸出—lombok

每次都使用 LoggerFactory.getLogger(xxx.class) 很繁瑣,而且每個(gè)類都要添加一遍,也很麻煩,這里有種更好的日志輸出方式,使用 lombok 來更簡(jiǎn)單的輸出。

  • 添加 lombok 框架支持
  • 使用 @slf4j 注解輸出日志

6.1 添加 lombok 到當(dāng)前項(xiàng)目

1.在 pom.xml 中先刪除已有的 lombok 依賴

2.下載插件

下載好之后,手動(dòng)引入 lombok 依賴

6.2 使用 @Slf4j 得到日志對(duì)象 log

@Controller
@ResponseBody
@Slf4j // 替代了之前需要通過 LoggerFactory.getLogger 操作
public class UserService {
        @RequestMapping("/sayhi2")
        public void sayHi2() {
                log.trace("我是 trace");
                log.debug("我是 debug");
                log.info("我是 info");
                log.warn("我是 warn");
                log.error("我是 error");
        }
}

控制臺(tái)打印結(jié)果如下:

總結(jié)

?志是程序中的重要組成部分,使??志可以快速的發(fā)現(xiàn)和定位問題,Spring Boot 內(nèi)容了?志框架, 默認(rèn)情況下使?的是 info ?志級(jí)別將?志輸出到控制臺(tái)的,我們可以通過 lombok 提供的 @Slf4j 注解 和 log 對(duì)象快速的打印?定義?志,?志包含 6 個(gè)級(jí)別:

  • trace:微量,少許的意思,級(jí)別最低;
  • info:普通的打印信息;
  • debug:需要調(diào)試時(shí)候的關(guān)鍵信息打??;
  • warn:警告,不影響使?,但需要注意的問題;
  • error:錯(cuò)誤信息,級(jí)別較?的錯(cuò)誤?志信息;
  • fatal:致命的,因?yàn)榇a異常導(dǎo)致程序退出執(zhí)?的事件。

?志級(jí)別依次提升,??志界別越?,收到的?志信息也就越少,我們可以通過配置?志的保存名稱或 保存?錄來將?志永久地保存下來。

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

相關(guān)文章

  • navicatdesignquery.sql.bak系統(tǒng)找不到指定路徑錯(cuò)誤的解決方法

    navicatdesignquery.sql.bak系統(tǒng)找不到指定路徑錯(cuò)誤的解決方法

    今天小編就為大家分享一篇關(guān)于navicatdesignquery.sql.bak系統(tǒng)找不到指定路徑錯(cuò)誤的解決方法,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2018-12-12
  • Java實(shí)現(xiàn)List集合手動(dòng)分頁的方法

    Java實(shí)現(xiàn)List集合手動(dòng)分頁的方法

    在工作中難免會(huì)遇到,將組裝的集合數(shù)據(jù)進(jìn)行分頁處理,本文主要介紹了Java實(shí)現(xiàn)List集合手動(dòng)分頁的方法,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-03-03
  • SpringCloud客戶端的負(fù)載均衡Ribbon的實(shí)現(xiàn)

    SpringCloud客戶端的負(fù)載均衡Ribbon的實(shí)現(xiàn)

    微服務(wù)架構(gòu),不可避免的存在單個(gè)微服務(wù)有多個(gè)實(shí)例,這篇文章主要介紹了SpringCloud客戶端的負(fù)載均衡Ribbon的實(shí)現(xiàn),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-06-06
  • springboot?maven?plugin報(bào)紅的解決辦法

    springboot?maven?plugin報(bào)紅的解決辦法

    本文主要介紹了springboot?maven?plugin報(bào)紅的解決辦法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • 將下載好的jar包導(dǎo)入到本地maven倉庫中操作

    將下載好的jar包導(dǎo)入到本地maven倉庫中操作

    這篇文章主要介紹了將下載好的jar包導(dǎo)入到本地maven倉庫中操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • java實(shí)現(xiàn)圖片加水印效果

    java實(shí)現(xiàn)圖片加水印效果

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)圖片加水印效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-12-12
  • java IP地址網(wǎng)段計(jì)算的示例代碼

    java IP地址網(wǎng)段計(jì)算的示例代碼

    這篇文章主要介紹了java IP地址網(wǎng)段計(jì)算的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • Java 8新增的方法參數(shù)反射實(shí)例分析

    Java 8新增的方法參數(shù)反射實(shí)例分析

    這篇文章主要介紹了Java 8新增的方法參數(shù)反射,結(jié)合實(shí)例形式分析了java8新增api方法參數(shù)反射相關(guān)操作技巧,需要的朋友可以參考下
    2019-07-07
  • SpringBoot請(qǐng)求參數(shù)相關(guān)注解說明小結(jié)

    SpringBoot請(qǐng)求參數(shù)相關(guān)注解說明小結(jié)

    這篇文章主要介紹了SpringBoot請(qǐng)求參數(shù)相關(guān)注解說明,主要包括@PathVariable,@RequestHeader、@CookieValue、@RequestBody和@RequestParam,本文結(jié)合實(shí)例代碼給大家講解的非常詳細(xì),需要的朋友可以參考下
    2022-05-05
  • 關(guān)于springBoot yml文件的list讀取問題總結(jié)(親測(cè))

    關(guān)于springBoot yml文件的list讀取問題總結(jié)(親測(cè))

    這篇文章主要介紹了關(guān)于springBoot yml文件的list讀取問題總結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-12-12

最新評(píng)論