springboot?log4j2日志框架整合與使用過程解析

一、引入maven依賴
Spring Boot默認(rèn)使用LogBack,但是我們沒有看到顯示依賴的jar包,其實(shí)是因?yàn)樗诘膉ar包spring-boot-starter-logging都是作為spring-boot-starter-web或者spring-boot-starter依賴的一部分。
如果這里要使用Log4j2,需要從spring-boot-starter-web中去掉spring-boot-starter-logging依賴,同時(shí)顯示聲明使用Log4j2的依賴jar包,具體如下:
<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>另外log4j是之前使用比較廣泛的軟件,容易與log4j2發(fā)生沖突,如果沖突將log4j從相應(yīng)的軟件里面排除掉,比如:dozer
<dependency>
<groupId>net.sf.dozer</groupId>
<artifactId>dozer</artifactId>
<version>5.4.0</version>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
</exclusion>
</exclusions>
</dependency>
二、添加配置文件log4j2-spring.xml
在resources目錄下新建一個(gè)log4j2-spring.xml文件,放在src/main/resources目錄下即可被Spring Boot應(yīng)用識(shí)別。
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<properties>
<!--日志輸出位置-->
<property name="LOG_HOME">D:/logs</property>
</properties>
<Appenders>
<!-- 將日志輸出到控制臺(tái)-->
<Console name="CONSOLE" target="SYSTEM_OUT">
<!--設(shè)置日志格式及顏色-->
<PatternLayout
pattern="[%style{%d}{bright,green}][%highlight{%p}][%style{%t}{bright,blue}][%style{%C}{bright,yellow}]: %msg%n%style{%throwable}{red}"
disableAnsi="false" noConsoleNoAnsi="false"/>
</Console>
<!-- 將日志輸出到文件-->
<RollingFile name="FILE-APPENDER"
fileName="${LOG_HOME}/log4j2-demo.log"
filePattern="${LOG_HOME}/log4j2-demo-%d{yyyy-MM-dd}-%i.log">
<!--設(shè)置日志格式-->
<PatternLayout>
<pattern>[%d][%p][%t][%C] %m%n</pattern>
</PatternLayout>
<Policies>
<!-- 設(shè)置日志文件切分參數(shù) -->
<SizeBasedTriggeringPolicy size="100 MB"/>
<TimeBasedTriggeringPolicy/>
</Policies>
<!--設(shè)置最大存檔數(shù)-->
<DefaultRolloverStrategy max="20"/>
</RollingFile>
</Appenders>
<Loggers>
<!-- 根日志設(shè)置 -->
<Root level="debug">
<AppenderRef ref="CONSOLE" level="debug"/>
<AppenderRef ref="FILE-APPENDER" level="info"/>
</Root>
<!--spring日志-->
<Logger name="org.springframework" level="info"/>
<!-- mybatis日志 -->
<Logger name="com.mybatis" level="warn"/>
</Loggers>
</configuration>
- 上文兩個(gè)Appender,一個(gè)叫做CONSOLE用于輸出日志到控制臺(tái),一個(gè)叫做FILE-APPENDER輸出日志到文件
- PatternLayout用于指定輸出日志的格式,
[%d][%p][%t][%C] %m%n這些占位符將結(jié)合下文測(cè)試結(jié)果為大家介紹 - Policies用于指定文件切分參數(shù)
- TimeBasedTriggeringPolicy默認(rèn)的size是1,結(jié)合filePattern定義%d{yyyy-MM-dd},則每天生成一個(gè)文件(最小的時(shí)間切分粒度是小時(shí))
<SizeBasedTriggeringPolicy size="100 MB"/>當(dāng)文件大小到100MB的時(shí)候,切分一個(gè)新的日志文件<DefaultRolloverStrategy max="20"/>表示文件最大的存檔數(shù)量,多余的將被刪除- 上文中的日志格式占位符號(hào),在文末測(cè)試的時(shí)候?yàn)榇蠹医榻B。
三、自定義配置文件
但是我們通常會(huì)有這樣一個(gè)需求,就是不同的環(huán)境使用不同的配置,比如:我們需要三個(gè)log4j2 xml文件:
- log4j2-dev.xml 開發(fā)環(huán)境日志配置
- log4j2-prod.xml 生產(chǎn)環(huán)境日志配置
- log4j2-test.xml 測(cè)試環(huán)境日志配置
但是Spring Boot并不知道log4j2-<profile>.xml這些配置文件是干什么的,所以需要通過在application.yml文件中顯示聲明才行。
舉例:在application-dev.yml里面使用log4j2-dev.xml配置文件
logging:
config: classpath:log4j2-dev.xml
以此類推,在application-prod.yml里面使用log4j2-prod.xml配置文件,在application-test.yml里面使用log4j2-test.xml配置文件。
四、測(cè)試一下
寫個(gè)Controller測(cè)試一下
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
@RestController
public class LogTestController {
private static final Logger logger = LoggerFactory.getLogger(LogTestController.class);
@GetMapping("/testlog")
public void test(){
logger.trace("Trace 日志...");
logger.debug("Debug 日志...");
logger.info("Info 日志...");
logger.warn("Warn 日志...");
logger.error("Error 日志...");
}
}日志輸出效果如下:

結(jié)合下面代碼說一下占位符
<PatternLayout pattern="[%style{%d}{bright,green}][%highlight{%p}][%style{%t}{bright,blue}][%style{%C}{bright,yellow}]: %msg%n%style{%throwable}{red}"
disableAnsi="false" noConsoleNoAnsi="false"/>
- %d : date時(shí)間
- %p : 日志級(jí)別
- %t : thread線程名稱
- %C: class類文件名稱
- %msg:日志信息
- %n:換行
- %style{%throwable}{red} 加樣式,異常信息紅色顯示
到此這篇關(guān)于springboot log4j2日志框架整合與使用的文章就介紹到這了,更多相關(guān)springboot log4j2日志框架內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
AbstractProcessor擴(kuò)展MapStruct自動(dòng)生成實(shí)體映射工具類
這篇文章主要為大家介紹了AbstractProcessor擴(kuò)展MapStruct自動(dòng)生成實(shí)體映射工具類實(shí)現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01
Mybatis-plus獲取雪花算法生成的ID并返回生成ID
本文主要介紹了Mybatis-plus獲取雪花算法生成的ID并返回生成ID,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-09-09
Java實(shí)現(xiàn)向Word文檔添加文檔屬性
這篇文章主要介紹了Java實(shí)現(xiàn)向Word文檔添加文檔屬性的相關(guān)資料,需要的朋友可以參考下2023-01-01
詳解spring cloud hystrix 請(qǐng)求合并collapsing
這篇文章主要介紹了詳解spring cloud hystrix 請(qǐng)求合并collapsing,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-05-05
java錯(cuò)誤:無效的源發(fā)行版:18解決辦法圖文詳解
在Java開發(fā)中,如果你遇到錯(cuò)誤: 無效的源發(fā)行版,這通常意味著你正在使用的Java編譯器(通常是javac)被配置為編譯一個(gè)比你的JDK 版本更高,這篇文章主要給大家介紹了關(guān)于java錯(cuò)誤:無效的源發(fā)行版:18的解決辦法,需要的朋友可以參考下2024-08-08
詳解Spring Security 中的四種權(quán)限控制方式
這篇文章主要介紹了詳解Spring Security 中的四種權(quán)限控制方式,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10

