springboot?log4j2日志框架整合與使用過程解析
一、引入maven依賴
Spring Boot默認使用LogBack,但是我們沒有看到顯示依賴的jar包,其實是因為所在的jar包spring-boot-starter-logging都是作為spring-boot-starter-web或者spring-boot-starter依賴的一部分。
如果這里要使用Log4j2,需要從spring-boot-starter-web中去掉spring-boot-starter-logging依賴,同時顯示聲明使用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從相應的軟件里面排除掉,比如: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目錄下新建一個log4j2-spring.xml文件,放在src/main/resources目錄下即可被Spring Boot應用識別。
<?xml version="1.0" encoding="UTF-8"?> <configuration> <properties> <!--日志輸出位置--> <property name="LOG_HOME">D:/logs</property> </properties> <Appenders> <!-- 將日志輸出到控制臺--> <Console name="CONSOLE" target="SYSTEM_OUT"> <!--設置日志格式及顏色--> <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"> <!--設置日志格式--> <PatternLayout> <pattern>[%d][%p][%t][%C] %m%n</pattern> </PatternLayout> <Policies> <!-- 設置日志文件切分參數(shù) --> <SizeBasedTriggeringPolicy size="100 MB"/> <TimeBasedTriggeringPolicy/> </Policies> <!--設置最大存檔數(shù)--> <DefaultRolloverStrategy max="20"/> </RollingFile> </Appenders> <Loggers> <!-- 根日志設置 --> <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>
- 上文兩個Appender,一個叫做CONSOLE用于輸出日志到控制臺,一個叫做FILE-APPENDER輸出日志到文件
- PatternLayout用于指定輸出日志的格式,
[%d][%p][%t][%C] %m%n
這些占位符將結合下文測試結果為大家介紹 - Policies用于指定文件切分參數(shù)
- TimeBasedTriggeringPolicy默認的size是1,結合filePattern定義%d{yyyy-MM-dd},則每天生成一個文件(最小的時間切分粒度是小時)
<SizeBasedTriggeringPolicy size="100 MB"/>
當文件大小到100MB的時候,切分一個新的日志文件<DefaultRolloverStrategy max="20"/>
表示文件最大的存檔數(shù)量,多余的將被刪除- 上文中的日志格式占位符號,在文末測試的時候為大家介紹。
三、自定義配置文件
但是我們通常會有這樣一個需求,就是不同的環(huán)境使用不同的配置,比如:我們需要三個log4j2 xml文件:
- log4j2-dev.xml 開發(fā)環(huán)境日志配置
- log4j2-prod.xml 生產(chǎn)環(huán)境日志配置
- log4j2-test.xml 測試環(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配置文件。
四、測試一下
寫個Controller測試一下
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 日志..."); } }
日志輸出效果如下:
結合下面代碼說一下占位符
<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時間
- %p : 日志級別
- %t : thread線程名稱
- %C: class類文件名稱
- %msg:日志信息
- %n:換行
- %style{%throwable}{red} 加樣式,異常信息紅色顯示
到此這篇關于springboot log4j2日志框架整合與使用的文章就介紹到這了,更多相關springboot log4j2日志框架內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Spring Boot中Reactor模型的基本概念和最佳實踐
Reactor模型是一種基于事件驅動和非阻塞IO的編程模型,用于處理并發(fā)和異步操作,本文將介紹Spring Boot中使用Reactor模型的基本概念和最佳實踐,幫助讀者更好地理解如何利用這一強大的工具來構建現(xiàn)代化的Java應用程序,感興趣的朋友跟隨小編一起看看吧2024-05-05項目總結之HttpURLConnection的disconnect的問題
這篇文章主要介紹了項目總結之HttpURLConnection的disconnect的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06Springmvc數(shù)據(jù)回顯實現(xiàn)原理實例解析
這篇文章主要介紹了Springmvc數(shù)據(jù)回顯實現(xiàn)原理實例解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-09-09Spring Boot使用過濾器和攔截器分別實現(xiàn)REST接口簡易安全認證示例代碼詳解
這篇文章主要介紹了Spring Boot使用過濾器和攔截器分別實現(xiàn)REST接口簡易安全認證示例代碼,通過開發(fā)實踐,理解過濾器和攔截器的工作原理,需要的朋友可以參考下2018-06-06