提供樣本配置代碼
```xml
<?xml version="1.0" encoding="UTF-8"?>
<!--日志級別以及優(yōu)先級排序: OFF > FATAL > ERROR > WARN > INFO > DEBUG > TRACE > ALL -->
<!-- status log4j2內(nèi)部日志級別 -->
<configuration status="INFO">
<!-- 全局參數(shù) -->
<Properties>
<Property name="springName">demo</Property>
<Property name="pattern">
{"time":"%d{yyyy-MM-dd HH:mm:ss.SSS}","level":"%level","service":"${springName}","class":"%C{1.}","thread":"%thread","trace":"[%X{traceId},%X{parentSpanId},%X{spanId}]","uri":"%X{URI}","device-type":"%X{DT}","source-type":"%X{ST}","uid":"%X{UID}","msg":"%msg"}%n
</Property>
</Properties>
<Appenders>
<RollingFile name="error" fileName="/home/logs/${springName}/err.log"
filePattern="/home/logs/${springName}/%d{yyyy-MM-dd}/err-%i.log" append="true">
<ThresholdFilter level="ERROR" onMatch="ACCEPT" onMismatch="DENY"/>
<PatternLayout>
<pattern>${pattern}</pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy modulate="true" interval="1"/>
<SizeBasedTriggeringPolicy size="30MB"/>
</Policies>
<DefaultRolloverStrategy>
<Delete basePath="/home/logs/${springName}/" maxDepth="2">
<IfFileName glob="err-*" />
<IfLastModified age="15d" />
</Delete>
</DefaultRolloverStrategy>
<DefaultRolloverStrategy max="30"/>
</RollingFile>
<RollingFile name="rollingFile" fileName="/home/logs/${springName}/demo.log"
filePattern="/home/logs/${springName}/%d{yyyy-MM-dd}/log-%i.log" append="true">
<PatternLayout>
<pattern>${pattern}</pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy modulate="true" interval="1"/>
<SizeBasedTriggeringPolicy size="10MB"/>
</Policies>
<DefaultRolloverStrategy max="50"/>
</RollingFile>
</Appenders>
<Loggers>
<Logger name="org.springframework" level="warn"/>
<Logger name="com.cc" level="info"/>
<Logger name="com.ap" level="DEBUG"/>
<Root level="info">
<AppenderRef ref="console"/>
<AppenderRef ref="error"></AppenderRef>
<AppenderRef ref="rollingFile"></AppenderRef>
</Root>
</Loggers>
</configuration>
``
配置說明
Log4j有三個(gè)主要的組件:
Loggers(記錄器):日志類別和級別
Appenders(輸出目標(biāo)):日志要輸出到的地方
Layouts(布局):日志以何種形式輸出
Propertiess說明
Properties全局參數(shù)
可以定義springName和pattern格式,全局使用。
Loggers組件
Loggers組件在此系統(tǒng)中被分為五個(gè)級別:DEBUG、INFO、WARN、ERROR和FATAL。這五個(gè)級別是有順序的,DEBUG < INFO < WARN < ERROR < FATAL,分別用來指定這條日志信息的重要程度,明白這一點(diǎn)很重要!
Log4j有一個(gè)規(guī)則:只輸出級別不低于設(shè)定級別的日志信息,假設(shè)Loggers級別設(shè)定為INFO,則INFO、WARN、ERROR和FATAL級別的日志信息都會輸出,而級別比INFO低的DEBUG則不會輸出。
Appenders配置
禁用和使用日志請求只是Log4j的基本功能,Log4j日志系統(tǒng)還提供了許多強(qiáng)大的功能,比如允許把日志輸出到不同的地方,如控制臺(Console)、文件(Files)等,可以根據(jù)天數(shù)或者文件大小產(chǎn)生新的文件,可以以流的形式發(fā)送到其它地方等等。
<Console>(控制臺)
<File>(文件)
<DailyRollingFile>(每天產(chǎn)生一個(gè)日志文件)
<RollingFile>(文件大小到達(dá)指定尺寸的時(shí)候產(chǎn)生一個(gè)新的文件)
<Writer>(將日志信息以流格式發(fā)送到任意指定的地方)
ThresholdFilter指定級別
Layouts配置
Log4j可以在Appenders的后面附加Layouts來完成這個(gè)功能。
Layouts提供四種日志輸出樣式,如根據(jù)HTML樣式、自由指定樣式、包含日志級別與信息的樣式和包含日志時(shí)間、線程、類別等信息的樣式。
常使用的類如下:
(以HTML表格形式布局)
(可以靈活地指定布局模式)
(包含日志信息的級別和信息字符串)
(包含日志產(chǎn)生的時(shí)間、線程、類別等信息)
PatternLayout選項(xiàng)
{"time":"%d{yyyy-MM-dd HH:mm:ss.SSS}","level":"%level","service":"${springAppName}","class":"%C{1.}","thread":"%thread","trace":"[%X{traceId},%X{parentSpanId},%X{spanId}]","uri":"%X{URI}","device-type":"%X{DT}","source-type":"%X{ST}","uid":"%X{UID}","msg":"%msg"}%n
格式說明如下:
%p:輸出日志信息的優(yōu)先級,即DEBUG,INFO,WARN,ERROR,F(xiàn)ATAL。
%d:輸出日志時(shí)間點(diǎn)的日期或時(shí)間,默認(rèn)格式為ISO8601,也可以在其后指定格式,如:%d{yyyy/MM/dd HH:mm:ss,SSS}。
%r:輸出自應(yīng)用程序啟動(dòng)到輸出該log信息耗費(fèi)的毫秒數(shù)。
%t:輸出產(chǎn)生該日志事件的線程名。
%l:輸出日志事件的發(fā)生位置,相當(dāng)于%c.%M(%F:%L)的組合,包括類全名、方法、文件名以及在代碼中的行數(shù)。例如:test.TestLog4j.main(TestLog4j.java:10)。
%c:輸出日志信息所屬的類目,通常就是所在類的全名。
%M:輸出產(chǎn)生日志信息的方法名。
%F:輸出日志消息產(chǎn)生時(shí)所在的文件名稱。
%L:輸出代碼中的行號。
%m:輸出代碼中指定的具體日志信息。
%n:輸出一個(gè)回車換行符,Windows平臺為"\r\n",Unix平臺為"\n"。
%x:輸出和當(dāng)前線程相關(guān)聯(lián)的NDC(嵌套診斷環(huán)境),尤其用到像Java Servlets這樣的多客戶多線程的應(yīng)用中。
%%:輸出一個(gè)"%"字符。
另外,還可以在%與格式字符之間加上修飾符來控制其最小長度、最大長度、和文本的對齊方式。如:文章來源:http://www.zghlxwxcb.cn/news/detail-812901.html
%20c:指定輸出category的名稱,最小的長度是20,如果category的名稱長度小于20的話,默認(rèn)的情況下右對齊。
%-20c:"-"號表示左對齊。
%.30c:指定輸出category的名稱,最大的長度是30,如果category的名稱長度大于30的話,就會將左邊多出的字符截掉,但小于30的話也不會補(bǔ)空格。文章來源地址http://www.zghlxwxcb.cn/news/detail-812901.html
Policies策略
基于時(shí)間的觸發(fā)策略。 interval,integer型,指定兩次封存動(dòng)作之間的時(shí)間間隔。單位:以日志的命名(filePattern)精度來確定單位,比如yyyy-MM-dd-HH單位為小時(shí),yyyy-MM-dd-HH-mm單位為分鐘 modulate,boolean型,說明是否對封存時(shí)間進(jìn)行調(diào)制。若modulate=true,以0為邊界封存 每文件最大字節(jié) 用來指定同一個(gè)文件夾下最多有幾個(gè)日志文件時(shí)開始刪除最舊的,創(chuàng)建新的(通過max屬性)。到了這里,關(guān)于springboot log4j配置xml實(shí)例說明的文章就介紹完了。如果您還想了解更多內(nèi)容,請?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!