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

Spring?Boot?3中一套可以直接用于生產(chǎn)環(huán)境的Log4J2日志配置詳解

 更新時間:2023年12月18日 09:18:44   作者:晨曦蝸牛  
Log4J2是Apache Log4j的升級版,參考了logback的一些優(yōu)秀的設(shè)計,并且修復(fù)了一些問題,因此帶來了一些重大的提升,這篇文章主要介紹了Spring?Boot?3中一套可以直接用于生產(chǎn)環(huán)境的Log4J2日志配置,需要的朋友可以參考下

一 Log4J2 相關(guān)概念及基本特點

Log4J2是Apache Log4j的升級版,參考了logback的一些優(yōu)秀的設(shè)計,并且修復(fù)了一些問題,因此帶來了一些重大的提升。
Logger:日志記錄器,用于標識日志的來源。常見的有兩種:Root和Logger。Root節(jié)點用來指定項目的根日志,如果沒有單獨指定Logger,那么就會默認使用該Root日志輸出
Appender:日志輸出器,用于將日志記錄輸出到指定的目標。常見的有三種子節(jié)點:Console、RollingFile、File。Console節(jié)點用來定義輸出到控制臺的Appender;RollingFile節(jié)點用來定義超過指定條件自動刪除舊的創(chuàng)建新的Appender;File節(jié)點用來定義輸出到指定位置的文件的Appender。
Layout:日志格式化器,用于定義日志記錄的輸出格式。Root節(jié)點用來指定項目的根日志,如果沒有單獨指定Logger,那么就會默認使用該Root日志輸出。

二 Spring Boot3 中啟用Log4J2的pom.xml配置

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter-logging</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-log4j2</artifactId>
        </dependency>

排除原依賴中的日志相關(guān)包,單獨引入Log4J2依賴。

三 application.properties 的配置

# 控制臺輸出的字符集
logging.charset.console=UTF-8
# 日志寫入文件的字符集
logging.charset.file=UTF-8
# Log4J2自定義配置的路徑,放置到resources目錄下
logging.config=classpath:logback.xml
# 應(yīng)用程序包的路徑
logging.level.com.test=INFO
# 日志存放路徑
logging.file.path=logs/test.log

四 完整配置

配置文件的名稱為:logback.xml,放置于resources目錄下。

<?xml
 version="1.0" encoding="UTF-8"?>
 <!--status:用來指定log4j2本身的打印日志的級別,monitorinterval:用于指定log4j自動重新配置的監(jiān)測間隔時間,單位是s,最小是5s-->
<Configuration status="WARN" monitorInterval="30">
    <Properties>
        <Property name="logDir">logs</Property>
        <Property name="logFile">cmams</Property>
        <Property name="level">DEBUG</Property>
    </Properties>
    <Appenders>
        <Console name="Console" target="SYSTEM_OUT">
            <PatternLayout pattern="[%-4level] [%date{yyyy-MM-dd HH:mm:ss.SSS}] [%thread] %logger{96}:%line - %msg%n"/>
            <!--控制臺只輸出level及其以上級別的信息(onMatch),其他的直接拒絕(onMismatch)-->
            <ThresholdFilter level="INFO" onMatch="ACCEPT" onMismatch="DENY"/>
        </Console>
        <RollingFile name="File" fileName="${logDir}/${logFile}.log"
                     filePattern="${logDir}/${logFile}-%d{yyyy-MM-dd}-%i.log.gz">
            <!--日志輸出格式-->
            <PatternLayout pattern="[%-4level] [%date{yyyy-MM-dd HH:mm:ss.SSS}] [%thread] %logger{96}:%line - %msg%n"/>
            <!--滿足任何一個policy即進行歸檔-->
            <Policies>
                <!--當(dāng)前日志與開始日期不匹配(RollingFile中配置的filePattern中配置的最小時間單位不匹配時)時進行歸檔-->
                <TimeBasedTriggeringPolicy/>
                <!--文件超過512M進行歸檔,SizeBasedTriggeringPolicy規(guī)定了當(dāng)日志文件達到了指定的size時,觸發(fā)rollover操作。size參數(shù)可以用KB、MB、GB等做后綴來指定具體的字節(jié)數(shù),如20MB-->
                <SizeBasedTriggeringPolicy size="64MB"/>
            </Policies>
            <!--歸檔的文件最大數(shù)量,max參數(shù)指定了計數(shù)器的最大值。一旦計數(shù)器達到了最大值,過舊的文件將被刪除。-->
            <DefaultRolloverStrategy max="20">
                <!--刪除規(guī)則-->
                <Delete basePath="${logDir}" maxDepth="2">
                    <!--匹配文件規(guī)則-->
                    <IfFileName glob="*.log.gz">
                        <IfLastModified age="60d">
                            <IfAny>
                                <!--logDir下文件總大小超過5GB,進行刪除-->
                                <IfAccumulatedFileSize exceeds="5GB"/>
                                <!--logDir下文件總數(shù)量超過100,進行刪除-->
                                <IfAccumulatedFileCount exceeds="100"/>
                            </IfAny>
                        </IfLastModified>
                    </IfFileName>
                </Delete>
            </DefaultRolloverStrategy>
        </RollingFile>
    </Appenders>
    <Loggers>
    <!--若是additivity設(shè)為false,則 子Logger 只會在自己的appender里輸出,而不會在 父Logger 的appender里輸出。-->
        <Logger name="com.cxwn.cmams" level="${level}" additivity="false">
            <AppenderRef ref="File"/>
            <AppenderRef ref="Console"/>
        </Logger>
        <Logger name="org.springframework" level="ERROR" additivity="false">
            <AppenderRef ref="Console"/>
            <AppenderRef ref="File"/>
        </Logger>
        <Root level="WARN">
            <AppenderRef ref="Console"/>
            <AppenderRef ref="File"/>
        </Root>
    </Loggers>
</Configuration>

到此這篇關(guān)于Spring Boot 3中一套可以直接用于生產(chǎn)環(huán)境的Log4J2日志配置的文章就介紹到這了,更多相關(guān)Spring Boot 3 Log4J2日志配置內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MyBatis批量插入的五種方式

    MyBatis批量插入的五種方式

    這篇文章主要介紹了MyBatis批量插入的五種方式,每種方式結(jié)合實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-11-11
  • Java并發(fā)編程中的ConcurrentLinkedQueue詳解

    Java并發(fā)編程中的ConcurrentLinkedQueue詳解

    這篇文章主要介紹了Java并發(fā)編程中的ConcurrentLinkedQueue詳解,GetThread線程不會因為ConcurrentLinkedQueue隊列為空而等待,而是直接返回null,所以當(dāng)實現(xiàn)隊列不空時,等待時,則需要用戶自己實現(xiàn)等待邏輯,需要的朋友可以參考下
    2023-12-12
  • spring自定義一個簡單的Starter啟動器

    spring自定義一個簡單的Starter啟動器

    這篇文章主要介紹了spring自定義一個簡單的Starter啟動器,一個 starter其實就是對一個功能的集成封裝,然后對外提供一個依賴,讓業(yè)務(wù)去使用,像我們熟悉的 Redis,mongo,mybatis 等均屬于,需要的朋友可以參考下
    2023-07-07
  • linux系統(tǒng)下java項目在后臺啟動的4種方式總結(jié)

    linux系統(tǒng)下java項目在后臺啟動的4種方式總結(jié)

    Linux是集多種功能于一身的操作系統(tǒng),它可以讓用戶查看和管理當(dāng)下正在運行的進程,包括Java程序,這篇文章主要給大家總結(jié)介紹了關(guān)于linux系統(tǒng)下java項目在后臺啟動的4種方式,需要的朋友可以參考下
    2023-10-10
  • HttpClient基礎(chǔ)解析

    HttpClient基礎(chǔ)解析

    這篇文章主要介紹了HttpClient基礎(chǔ)知識,算是比較詳細地對知識點和相關(guān)實例進行解釋,需要的朋友可以參考下
    2017-09-09
  • Windows7下的Java運行環(huán)境搭建過程圖解

    Windows7下的Java運行環(huán)境搭建過程圖解

    這篇文章主要介紹了Windows7下的Java運行環(huán)境搭建過程圖解,需要的朋友可以參考下
    2014-04-04
  • 基于Redis實現(xiàn)分布式應(yīng)用限流的方法

    基于Redis實現(xiàn)分布式應(yīng)用限流的方法

    本篇文章主要介紹了基于 Redis 實現(xiàn)分布式應(yīng)用限流的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-12-12
  • Java8新增的重復(fù)注解功能示例

    Java8新增的重復(fù)注解功能示例

    這篇文章主要介紹了Java8新增的重復(fù)注解功能,結(jié)合實例形式分析了java8重復(fù)注解的功能、定義、使用方法及相關(guān)操作注意事項,需要的朋友可以參考下
    2019-10-10
  • Springboot工具類FileCopyUtils使用教程

    Springboot工具類FileCopyUtils使用教程

    這篇文章主要介紹了Springboot內(nèi)置的工具類之FileCopyUtils的使用,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-12-12
  • Mybatis增強版MyBatis-Flex的具體使用

    Mybatis增強版MyBatis-Flex的具體使用

    Mybatis-Flex一個用于增強MyBatis的框架,本文主要介紹了Mybatis增強版MyBatis-Flex的具體使用,具有一定的參考價值,感興趣的可以了解一下
    2024-06-06

最新評論