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

SpringBoot日志進(jìn)階實(shí)戰(zhàn)之Logback配置經(jīng)驗(yàn)和方法

 更新時(shí)間:2023年06月02日 10:47:50   作者:天罡gg  
本文給大家介紹在SpringBoot中使用Logback配置日志的經(jīng)驗(yàn)和方法,并提供了詳細(xì)的代碼示例和解釋,包括:滾動(dòng)文件、異步日志記錄、動(dòng)態(tài)指定屬性、日志級(jí)別、配置文件等常用功能,覆蓋日常Logback配置開發(fā)90%的知識(shí)點(diǎn),感興趣的朋友跟隨小編一起看看吧

前言

在上一篇文章中,我和你介紹了SpringBoot快速入門Slf4j + Logback實(shí)戰(zhàn),遺留的問題是如何將日志輸出到文件。

今天這篇文章分享了我在SpringBoot中使用Logback配置日志的經(jīng)驗(yàn)和方法,并提供了詳細(xì)的代碼示例和解釋,包括:滾動(dòng)文件、異步日志記錄、動(dòng)態(tài)指定屬性、日志級(jí)別、配置文件等常用功能,覆蓋日常Logback配置開發(fā)90%的知識(shí)點(diǎn)!

一、Logback入門級(jí)配置

在tg-book-web的src\main\resources下創(chuàng)建logback-spring.xml文件,這里給出最簡單的輸出到控制臺(tái)文件的示例

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
	<!-- 定義屬性,可以通過“${}”來使用屬性 -->
    <property name="LOG_PATH" value="d:/logs/"/>
    <property name="APP_ID" value="tg-book"/>
	<!-- 把日志輸出到控制臺(tái) -->
    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>[%d{yyyy-MM-dd HH:mm:ss.SSS}] [%level] [%thread] %logger{36} %L - %msg%xEx%n</pattern>
        </encoder>
    </appender>
	<!-- 把日志輸出到文件 -->
    <appender name="FILE" class="ch.qos.logback.core.FileAppender">
        <encoder>
            <pattern>[%d{yyyy-MM-dd HH:mm:ss.SSS}] [%level] [%thread] %logger{36} %L - %msg%xEx%n</pattern>
            <charset>UTF-8</charset>
        </encoder>
        <file>${LOG_PATH}/${APP_ID}.log</file>
    </appender>
    <!-- 大于等于info級(jí)別的才會(huì)輸出 -->
    <root level="info">
        <appender-ref ref="STDOUT"/>
        <appender-ref ref="FILE"/>
    </root>
</configuration>

上面的配置,將輸出日志到文件d:/logs/tg-book.log中。

常用節(jié)點(diǎn)的解釋:

  1. configuration:根節(jié)點(diǎn),包含所有配置信息。
  2. property:定義屬性,可以通過“${}”來使用屬性
  3. appender:定義輸出器的名稱、類型、編碼、日志輸出路徑等信息。
  • class=“ch.qos.logback.core.ConsoleAppender”:輸出到控制臺(tái)
  • class=“ch.qos.logback.core.FileAppender”:輸出到文件
  1. root:定義日志記錄器的根節(jié)點(diǎn),指定默認(rèn)的日志記錄級(jí)別、輸出器等信息。

二、動(dòng)態(tài)指定屬性

定義springProperty標(biāo)簽,通過指定source來源于application.properties的配置值!

  • 修改上面的logback-spring.xml文件,僅將property 標(biāo)簽注釋,新增springProperty標(biāo)簽,如下:
<!--<property name="LOG_PATH" value="d:/logs/"/>
<property name="APP_ID" value="tg-book"/>-->
<springProperty name="LOG_PATH" source="log.path"/>
<springProperty name="APP_ID" source="app.id"/>
  • 修改application.properties文件,新增log.path和app.id配置:
app.id=tg-book
log.path=d:/logs/

三、動(dòng)態(tài)指定日志級(jí)別

可以在application.properties文件中設(shè)置logging.level.包路徑=日志級(jí)別來更改日志級(jí)別!

  • 例如,修改包org.tg.book.dal.mapper的日志級(jí)別=debug
logging.level.org.tg.book.dal.mapper = debug

此時(shí),我們調(diào)用login接口,將輸出debug級(jí)別的mybatis的sql日志,如下圖:

在這里插入圖片描述

也可以修改root的日志級(jí)別

logging.level.root= warn

此時(shí),所有包,將只輸出warn、error級(jí)別日志。

四、指定配置文件

可以在application.properties文件中設(shè)置logging.config=classpath:logback-spring-2.xml來指定配置文件,如果不指定默認(rèn)就是classpath:logback-spring.xml!

五、滾動(dòng)記錄RollingFIleAppender

RollingFileAppender:滾動(dòng)記錄文件,先將日志記錄到指定文件,當(dāng)符合某個(gè)策略條件時(shí),將日志記錄到其余文件。

我們新增一個(gè)RollingFileAppender,并修改root的appender-ref,詳細(xì)如下:

<!-- 把日志滾動(dòng)輸出到各文件 -->
<appender name="ROLLING_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <encoder>
        <pattern>[%d{yyyy-MM-dd HH:mm:ss.SSS}] [%level] [%thread] %logger{36} %L - %msg%xEx%n</pattern>
        <charset>UTF-8</charset>
    </encoder>
    <file>${LOG_PATH}/${APP_ID}-rolling.log</file>
    <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
        <fileNamePattern>${LOG_PATH}/${APP_ID}-%d{yyyyMMdd}-%i.log</fileNamePattern> 
        <maxFileSize>100MB</maxFileSize> <!-- 文件最大大小,可能會(huì)超出 -->
        <maxHistory>30</maxHistory>  <!-- 保存30天 -->
        <totalSizeCap>10GB</totalSizeCap><!-- 總?cè)罩敬笮?-->
    </rollingPolicy>
</appender>
<root level="info">
     <appender-ref ref="STDOUT"/>
     <appender-ref ref="ROLLING_FILE"/>
</root>

SizeAndTimeBasedRollingPolicy是常用的滾動(dòng)策略,配置節(jié)點(diǎn)說明如下:

  • maxFileSize:當(dāng)D:\logs\tg-book-rolling.log文件達(dá)到100MB以后,會(huì)自動(dòng)創(chuàng)建新文件!測(cè)試時(shí),你可以指定maxFileSize小一點(diǎn),比如100KB。
  • maxHistory:最大保存多長時(shí)間,單位是天
  • totalSizeCap:總?cè)罩敬笮?/li>

六、異步記錄AsyncAppender

AsyncAppender可以將日志消息異步地發(fā)送到目標(biāo)Appender,以提高應(yīng)用程序的性能和響應(yīng)速度。

我們新增兩個(gè)AsyncAppender,一個(gè)指定控制臺(tái),一個(gè)指定文件,如下:

<!-- 把日志異步輸出到控制臺(tái) -->
<appender name="ASYNC-STDOUT" class="ch.qos.logback.classic.AsyncAppender">
    <!-- 指定隊(duì)列滿載時(shí),消息將被丟棄的數(shù)量, 默認(rèn)值為0 -->
    <discardingThreshold>0</discardingThreshold>
    <!-- 隊(duì)列的大小, 默認(rèn)值為256 -->
    <queueSize>1024</queueSize>
    <!-- 隊(duì)列滿了不阻塞調(diào)用者-->
    <neverBlock>true</neverBlock>
    <!-- 異步打印堆棧信息不丟失-->
    <includeCallerData>true</includeCallerData>
    <!-- 添加附加的appender,最多只能添加一個(gè) -->
    <appender-ref ref="STDOUT"/>
</appender>
<!-- 把日志異步滾動(dòng)輸出到文件 -->
<appender name="ASYNC-FILE" class="ch.qos.logback.classic.AsyncAppender">
    <!-- 指定隊(duì)列滿載時(shí),消息將被丟棄的數(shù)量, 默認(rèn)值為0 -->
    <discardingThreshold>0</discardingThreshold>
    <!-- 隊(duì)列的大小, 默認(rèn)值為256 -->
    <queueSize>1024</queueSize>
    <!-- 隊(duì)列滿了不阻塞調(diào)用者-->
    <neverBlock>true</neverBlock>
    <!-- 異步打印堆棧信息不丟失-->
    <includeCallerData>true</includeCallerData>
    <!-- 添加附加的appender,最多只能添加一個(gè) -->
    <appender-ref ref="ROLLING_FILE"/>
</appender>
<!-- 大于等于info級(jí)別的才會(huì)輸出 -->
<root level="info">
    <!--<appender-ref ref="STDOUT"/>
    <appender-ref ref="ROLLING_FILE"/>-->
    <appender-ref ref="ASYNC-STDOUT"/>
    <appender-ref ref="ASYNC-FILE"/>
</root>

AsyncAppender具有以下參數(shù):

  • QueueSize:指定用于暫存消息的BlockingQueue隊(duì)列的大小。默認(rèn)值為256。
  • DiscardingThreshold:指定隊(duì)列滿載時(shí),消息將被丟棄的數(shù)量。默認(rèn)值為0。
  • NeverBlock:指定當(dāng)隊(duì)列已滿時(shí),是否阻止應(yīng)用程序運(yùn)行。如果設(shè)置為true,當(dāng)隊(duì)列已滿時(shí),應(yīng)用程序?qū)⒗^續(xù)運(yùn)行,但消息可能會(huì)丟失。默認(rèn)值為false。
  • IncludeCallerData:指定是否在記錄器中包含調(diào)用者信息。默認(rèn)值為false。
  • AppenderRef:指定一個(gè)或多個(gè)目標(biāo)Appender引用的列表。每個(gè)引用都必須引用一個(gè)已定義的Appender。
  • DiscardingThresholdPolicyClassName:指定當(dāng)隊(duì)列滿時(shí),應(yīng)采取的策略類的名稱。默認(rèn)使用的是DiscardingThresholdPolicy類。
  • QueueFullPolicyClassName:指定當(dāng)隊(duì)列已滿時(shí),應(yīng)采取的策略類的名稱。默認(rèn)使用的是DiscardingQueueFullPolicy類。

總結(jié)

最終的logback-spring.xml配置文件如下:

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <!-- 定義屬性,可以通過“${}”來使用屬性 -->
    <!--<property name="LOG_PATH" value="d:/logs/"/>
    <property name="APP_ID" value="tg-book"/>-->
    <springProperty name="LOG_PATH" source="log.path"/>
    <springProperty name="APP_ID" source="app.id"/>
    <!-- 把日志輸出到控制臺(tái) -->
    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>[%d{yyyy-MM-dd HH:mm:ss.SSS}] [%level] [%thread] %logger{36} %L - %msg%xEx%n</pattern>
        </encoder>
    </appender>
    <!-- 把日志輸出到文件 -->
    <appender name="FILE" class="ch.qos.logback.core.FileAppender">
        <encoder>
            <pattern>[%d{yyyy-MM-dd HH:mm:ss.SSS}] [%level] [%thread] %logger{36} %L - %msg%xEx%n</pattern>
            <charset>UTF-8</charset>
        </encoder>
        <file>${LOG_PATH}/${APP_ID}.log</file>
    </appender>
    <!-- 把日志滾動(dòng)輸出到各文件 -->
    <appender name="ROLLING_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <encoder>
            <pattern>[%d{yyyy-MM-dd HH:mm:ss.SSS}] [%level] [%thread] %logger{36} %L - %msg%xEx%n</pattern>
            <charset>UTF-8</charset>
        </encoder>
        <file>${LOG_PATH}/${APP_ID}-rolling.log</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <fileNamePattern>${LOG_PATH}/${APP_ID}-%d{yyyyMMdd}-%i.log</fileNamePattern>
            <maxFileSize>500KB</maxFileSize> <!-- 文件最大大小,可能會(huì)超出 -->
            <maxHistory>30</maxHistory>  <!-- 保存30天 -->
            <totalSizeCap>10GB</totalSizeCap><!-- 總?cè)罩敬笮?-->
        </rollingPolicy>
    </appender>
    <!-- 把日志異步輸出到控制臺(tái) -->
    <appender name="ASYNC-STDOUT" class="ch.qos.logback.classic.AsyncAppender">
        <!-- 指定隊(duì)列滿載時(shí),消息將被丟棄的數(shù)量, 默認(rèn)值為0 -->
        <discardingThreshold>0</discardingThreshold>
        <!-- 隊(duì)列的大小, 默認(rèn)值為256 -->
        <queueSize>1024</queueSize>
        <!-- 隊(duì)列滿了不阻塞調(diào)用者-->
        <neverBlock>true</neverBlock>
        <!-- 異步打印堆棧信息不丟失-->
        <includeCallerData>true</includeCallerData>
        <!-- 添加附加的appender,最多只能添加一個(gè) -->
        <appender-ref ref="STDOUT"/>
    </appender>
    <!-- 把日志異步滾動(dòng)輸出到文件 -->
    <appender name="ASYNC-FILE" class="ch.qos.logback.classic.AsyncAppender">
        <!-- 指定隊(duì)列滿載時(shí),消息將被丟棄的數(shù)量, 默認(rèn)值為0 -->
        <discardingThreshold>0</discardingThreshold>
        <!-- 隊(duì)列的大小, 默認(rèn)值為256 -->
        <queueSize>1024</queueSize>
        <!-- 隊(duì)列滿了不阻塞調(diào)用者-->
        <neverBlock>true</neverBlock>
        <!-- 異步打印堆棧信息不丟失-->
        <includeCallerData>true</includeCallerData>
        <!-- 添加附加的appender,最多只能添加一個(gè) -->
        <appender-ref ref="ROLLING_FILE"/>
    </appender>
    <!-- 大于等于info級(jí)別的才會(huì)輸出 -->
    <root level="info">
        <!--<appender-ref ref="STDOUT"/>
        <appender-ref ref="ROLLING_FILE"/>-->
        <appender-ref ref="ASYNC-STDOUT"/>
        <appender-ref ref="ASYNC-FILE"/>
    </root>
</configuration>

application.properties增加配置:

#logging.config=classpath:logback-spring.xml
app.id=tg-book
log.path=d:/logs/
logging.level.root = info
#logging.level.org.tg.book.dal.mapper = debug

到此這篇關(guān)于SpringBoot日志進(jìn)階實(shí)戰(zhàn) Logback配置詳解的文章就介紹到這了,更多相關(guān)SpringBoot Logback配置內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • java實(shí)現(xiàn)國產(chǎn)sm4加密算法

    java實(shí)現(xiàn)國產(chǎn)sm4加密算法

    這篇文章主要介紹了java實(shí)現(xiàn)國產(chǎn)sm4加密算法的步驟,幫助大家更好的理解和使用Java,感興趣的朋友可以了解下
    2020-12-12
  • SpringBoot整合定時(shí)任務(wù)的方法

    SpringBoot整合定時(shí)任務(wù)的方法

    通過 ThreadPoolExecutor 可以實(shí)現(xiàn)各式各樣的自定義線程池,而 ScheduledThreadPoolExecutor 類則在自定義線程池的基礎(chǔ)上增加了周期性執(zhí)行任務(wù)的功能,這篇文章主要介紹了SpringBoot整合定時(shí)任務(wù),需要的朋友可以參考下
    2024-05-05
  • 使用Swagger2實(shí)現(xiàn)自動(dòng)生成RESTful?API文檔

    使用Swagger2實(shí)現(xiàn)自動(dòng)生成RESTful?API文檔

    在開發(fā)?RESTful?API?的過程中,文檔是非常重要的一部分,可以幫助開發(fā)者了解?API?的功能和使用方法,本文將使用Swagger2?實(shí)現(xiàn)自動(dòng)生成?RESTful?API?文檔,需要的可以參考一下
    2023-06-06
  • 老生常談JVM的內(nèi)存溢出說明及參數(shù)調(diào)整

    老生常談JVM的內(nèi)存溢出說明及參數(shù)調(diào)整

    下面小編就為大家?guī)硪黄仙U凧VM的內(nèi)存溢出說明及參數(shù)調(diào)整。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-03-03
  • Java編程中使用XFire框架調(diào)用WebService程序接口

    Java編程中使用XFire框架調(diào)用WebService程序接口

    這篇文章主要介紹了Java編程中使用XFire調(diào)用WebService程序接口的方法,WebService是一種跨編程語言和跨操作系統(tǒng)平臺(tái)的遠(yuǎn)程調(diào)用技術(shù),需要的朋友可以參考下
    2015-12-12
  • Java線程池高頻面試題總結(jié)

    Java線程池高頻面試題總結(jié)

    在進(jìn)程和線程的相關(guān)面試題中還有一部分是關(guān)于多線程和線程池的,也是在這一部分中比較??疾斓膬?nèi)容。本篇文章就帶你了解一下,希望能給你帶來幫助
    2021-08-08
  • 教你如何用Java簡單爬取WebMagic

    教你如何用Java簡單爬取WebMagic

    今天給大家?guī)淼氖顷P(guān)于Java爬蟲的相關(guān)知識(shí),文章圍繞著Java如何爬取WebMagic展開,文中有非常詳細(xì)的介紹及代碼示例,需要的朋友可以參考下
    2021-06-06
  • springboot與dubbo的版本匹配問題

    springboot與dubbo的版本匹配問題

    這篇文章主要介紹了springboot與dubbo的版本匹配問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • SpringBoot整合SpringSecurityOauth2實(shí)現(xiàn)鑒權(quán)動(dòng)態(tài)權(quán)限問題

    SpringBoot整合SpringSecurityOauth2實(shí)現(xiàn)鑒權(quán)動(dòng)態(tài)權(quán)限問題

    這篇文章主要介紹了SpringBoot整合SpringSecurityOauth2實(shí)現(xiàn)鑒權(quán)-動(dòng)態(tài)權(quán)限,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-06-06
  • java后端進(jìn)行跨域的幾種方式小結(jié)

    java后端進(jìn)行跨域的幾種方式小結(jié)

    本文主要介紹了java后端進(jìn)行跨域的幾種方式小結(jié),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03

最新評(píng)論