本篇文章為大家展示了怎么在Spring 5.0中使用log4j2實現(xiàn)日志管理,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。
創(chuàng)新互聯(lián)建站網(wǎng)站建設(shè)公司一直秉承“誠信做人,踏實做事”的原則,不欺瞞客戶,是我們最起碼的底線! 以服務(wù)為基礎(chǔ),以質(zhì)量求生存,以技術(shù)求發(fā)展,成交一個客戶多一個朋友!專注中小微企業(yè)官網(wǎng)定制,做網(wǎng)站、網(wǎng)站建設(shè),塑造企業(yè)網(wǎng)絡(luò)形象打造互聯(lián)網(wǎng)企業(yè)效應(yīng)。先引入log4j 2的三個jar包
log4j-api-2.10.0.jar
log4j-core-2.10.0.jar
log4j-web-2.10.0.jar
項目下的web.xml文件加入,本設(shè)置讓日志文件使用${web:rootDir}輸出到web目錄下
log4jContextName myApplication
log4j 2支持JSON、YAML、properties、XML四種配置方式,我們按老規(guī)據(jù)使用 properties 配置 Log4j2
在項目的src目錄下加入log4j2.properties文件,spring 5.0默認(rèn)會自動加載該文件
# 設(shè)定Log4j2內(nèi)部的日志級別,有效值:trace, debug, info, warn, error, fatal。只對Log4j本身的事件有效,可以不設(shè)置,當(dāng)設(shè)置成trace時,會看到log4j2內(nèi)部各種詳細(xì)輸出 status = fatal # 配置的名稱 name =PropertiesConfig appenders = console,I #控制臺類型的日志輸出源 appender.console.type = Console #輸出源的名稱 appender.console.name = consoleLog #輸出布局類型 appender.console.layout.type = PatternLayout #輸出模板 appender.console.layout.pattern = %m%n appender.console.target = System_out # 文件滾動記錄類型的日志輸出源 appender.I.type = RollingFile # 當(dāng)前滾動輸出源的名稱,以便在Logger的配置項中能夠調(diào)用 appender.I.name = InfoRollingFile # 當(dāng)前正在操作的日志文件的文件名 appender.I.fileName = ${web:rootDir}/WEB-INF/log/info.log # 歸檔后的日志文件的文件名格式,其中`%d{yyyy-MM-dd-HH}`用來自動填充日期 appender.I.filePattern = ${web:rootDir}/WEB-INF/log/info_%d{MM-dd}_%i.log # 滾動記錄輸出源布局類型 appender.I.layout.type = PatternLayout # 滾動記錄輸出模板 appender.I.layout.pattern = %-d{yyyy-MM-dd HH:mm:ss} [ %p ] [ %c ] %m%n # 指定記錄文件的封存策略,該策略主要是完成周期性的日志文件封存工作 appender.I.policies.type = Policies # 基于時間進(jìn)行日志的切割 appender.I.policies.time.type = TimeBasedTriggeringPolicy # 切割的間隔為1月, 即每天進(jìn)行一次日志的歸檔,如果filePattern中配置的文件重命名規(guī)則是${web:rootDir}/WEB-INF/log/info_%d{yyyy-MM-dd HH-mm}-%i,最小的時間粒度是mm,即分鐘,TimeBasedTriggeringPolicy指定的size是1,結(jié)合起來就是每2分鐘生成一個新文件。如果改成%d{yyyy-MM-dd HH},最小粒度為小時,則每2個小時生成一個文件。 appender.I.policies.time.interval = 1 # 修正時間范圍, 從0時開始計數(shù)。若modulate=true,則封存時間將以0點為邊界進(jìn)行偏移計算。比如,modulate=true,interval=4hours,那么假設(shè)上次封存日志的時間為03:00,則下次封存日志的時間為04:00,之后的封存時間 appender.I.policies.time.modulate = true # 基于日志文件體積的觸發(fā)策略 appender.I.policies.size.type = SizeBasedTriggeringPolicy # 當(dāng)日志文件體積大于size指定的值時,觸發(fā)Rolling appender.I.policies.size.size=50M # 文件封存的覆蓋策略(RolloverStrategy) appender.I.strategy.type = DefaultRolloverStrategy # 生成分割(封存)文件的個數(shù) appender.I.strategy.max = 100 # 根日志,所有日志的父節(jié)點 級別順序(低到高):all < trace配置完成后寫個類測試一下
import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; public class TestClass{ public static final Logger logger = LogManager.getLogger(TestClass.class); public void test(){ logger.info("信息...."); } }上述內(nèi)容就是怎么在Spring 5.0中使用log4j2實現(xiàn)日志管理,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
新聞標(biāo)題:怎么在Spring5.0中使用log4j2實現(xiàn)日志管理-創(chuàng)新互聯(lián)
鏈接地址:http://weahome.cn/article/iejcd.html