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

Spring 5.0集成log4j2日志管理的示例代碼

 更新時(shí)間:2017年12月19日 10:20:47   作者:簡(jiǎn)言不簡(jiǎn)單  
本篇文章主要介紹了Spring 5.0集成log4j2日志管理的示例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

在使用Spring框架的時(shí)候,我們可以很方便的配置log4j來(lái)進(jìn)行日志管理。

Spring 5.0發(fā)布一段時(shí)間了,最近將項(xiàng)目從Spring 4.3升級(jí)到Spring 5.0,Spring 4.3集成log4j所用的類(lèi)org.springframework.web.util.Log4jConfigListener在Spring 5.0版本已經(jīng)刪除,而且log4j 1.x版已經(jīng)不再更新。我們將log4j-1.x升級(jí)為log4j-2.x

先引入log4j 2的三個(gè)jar包

  1. log4j-api-2.10.0.jar
  2. log4j-core-2.10.0.jar
  3. log4j-web-2.10.0.jar

項(xiàng)目下的web.xml文件加入,本設(shè)置讓日志文件使用${web:rootDir}輸出到web目錄下

<context-param>
  <param-name>log4jContextName</param-name>
  <param-value>myApplication</param-value>
</context-param>

log4j 2支持JSON、YAML、properties、XML四種配置方式,我們按老規(guī)據(jù)使用 properties 配置 Log4j2

在項(xiàng)目的src目錄下加入log4j2.properties文件,spring 5.0默認(rèn)會(huì)自動(dòng)加載該文件

# 設(shè)定Log4j2內(nèi)部的日志級(jí)別,有效值:trace, debug, info, warn, error, fatal。只對(duì)Log4j本身的事件有效,可以不設(shè)置,當(dāng)設(shè)置成trace時(shí),會(huì)看到log4j2內(nèi)部各種詳細(xì)輸出
status = fatal

# 配置的名稱(chēng)
name =PropertiesConfig
appenders = console,I

#控制臺(tái)類(lèi)型的日志輸出源
appender.console.type = Console
#輸出源的名稱(chēng)
appender.console.name = consoleLog
#輸出布局類(lèi)型
appender.console.layout.type = PatternLayout
#輸出模板
appender.console.layout.pattern = %m%n
appender.console.target = System_out 

# 文件滾動(dòng)記錄類(lèi)型的日志輸出源
appender.I.type = RollingFile
# 當(dāng)前滾動(dòng)輸出源的名稱(chēng),以便在Logger的配置項(xiàng)中能夠調(diào)用
appender.I.name = InfoRollingFile
# 當(dāng)前正在操作的日志文件的文件名
appender.I.fileName = ${web:rootDir}/WEB-INF/log/info.log
# 歸檔后的日志文件的文件名格式,其中`%d{yyyy-MM-dd-HH}`用來(lái)自動(dòng)填充日期
appender.I.filePattern = ${web:rootDir}/WEB-INF/log/info_%d{MM-dd}_%i.log
# 滾動(dòng)記錄輸出源布局類(lèi)型
appender.I.layout.type = PatternLayout
# 滾動(dòng)記錄輸出模板
appender.I.layout.pattern = %-d{yyyy-MM-dd HH:mm:ss} [ %p ] [ %c ] %m%n
# 指定記錄文件的封存策略,該策略主要是完成周期性的日志文件封存工作
appender.I.policies.type = Policies
# 基于時(shí)間進(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,最小的時(shí)間粒度是mm,即分鐘,TimeBasedTriggeringPolicy指定的size是1,結(jié)合起來(lái)就是每2分鐘生成一個(gè)新文件。如果改成%d{yyyy-MM-dd HH},最小粒度為小時(shí),則每2個(gè)小時(shí)生成一個(gè)文件。
appender.I.policies.time.interval = 1
# 修正時(shí)間范圍, 從0時(shí)開(kāi)始計(jì)數(shù)。若modulate=true,則封存時(shí)間將以0點(diǎn)為邊界進(jìn)行偏移計(jì)算。比如,modulate=true,interval=4hours,那么假設(shè)上次封存日志的時(shí)間為03:00,則下次封存日志的時(shí)間為04:00,之后的封存時(shí)間
appender.I.policies.time.modulate = true
# 基于日志文件體積的觸發(fā)策略
appender.I.policies.size.type = SizeBasedTriggeringPolicy
# 當(dāng)日志文件體積大于size指定的值時(shí),觸發(fā)Rolling
appender.I.policies.size.size=50M
# 文件封存的覆蓋策略(RolloverStrategy)
appender.I.strategy.type = DefaultRolloverStrategy
# 生成分割(封存)文件的個(gè)數(shù)
appender.I.strategy.max = 100

# 根日志,所有日志的父節(jié)點(diǎn) 級(jí)別順序(低到高):all < trace <debug < info < warn < error < fatal <off
rootLogger.level = debug
rootLogger.appenderRef.I.ref = InfoRollingFile
rootLogger.appenderRef.I.level = info

# 關(guān)聯(lián)名稱(chēng)為consoleLog的輸出源 注意consolelog小寫(xiě)
rootLogger.appenderRef.consolelog.ref = consoleLog
# 生產(chǎn)環(huán)境設(shè)為off關(guān)閉控制臺(tái)日志輸出
rootLogger.appenderRef.consolelog.level = debug

配置完成后寫(xiě)個(gè)類(lèi)測(cè)試一下

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("信息....");
  }
}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • JAVA裝飾者模式(從現(xiàn)實(shí)生活角度理解代碼原理)

    JAVA裝飾者模式(從現(xiàn)實(shí)生活角度理解代碼原理)

    裝飾者模式可以動(dòng)態(tài)地給一個(gè)對(duì)象添加一些額外的職責(zé)。就增加功能來(lái)說(shuō),Decorator模式相比生成子類(lèi)更為靈活。這篇文章主要介紹了JAVA裝飾者模式的相關(guān)資料,需要的朋友可以參考下
    2016-12-12
  • SpringBoot定時(shí)任務(wù)調(diào)度與爬蟲(chóng)的配置實(shí)現(xiàn)

    SpringBoot定時(shí)任務(wù)調(diào)度與爬蟲(chóng)的配置實(shí)現(xiàn)

    這篇文章主要介紹了SpringBoot定時(shí)任務(wù)調(diào)度與爬蟲(chóng)的實(shí)現(xiàn),使用webmagic開(kāi)發(fā)爬蟲(chóng),繼承PageProcessor接口編寫(xiě)自己的處理類(lèi),process是定制爬蟲(chóng)邏輯的核心接口,在這里編寫(xiě)抽取邏輯,具體實(shí)現(xiàn)配置過(guò)程跟隨小編一起看看吧
    2022-01-01
  • Java8的Lambda和排序

    Java8的Lambda和排序

    這篇文章主要介紹了Java8的Lambda和排序,對(duì)數(shù)組和集合進(jìn)行排序是Java 8 lambda令人驚奇的一個(gè)應(yīng)用,我們可以實(shí)現(xiàn)一個(gè)Comparators來(lái)實(shí)現(xiàn)各種排序,下面文章將有案例詳細(xì)說(shuō)明,想要了解得小伙伴可以參考一下
    2021-11-11
  • Spring?AOP中三種增強(qiáng)方式的示例詳解

    Spring?AOP中三種增強(qiáng)方式的示例詳解

    AOP?(Aspect?Orient?Programming),直譯過(guò)來(lái)就是?面向切面編程。AOP?是一種編程思想,是面向?qū)ο缶幊蹋∣OP)的一種補(bǔ)充。本文為大家介紹了Spring?AOP中三種增強(qiáng)方式,感興趣的可以了解一下
    2022-07-07
  • 圖解Java經(jīng)典算法希爾排序的原理與實(shí)現(xiàn)

    圖解Java經(jīng)典算法希爾排序的原理與實(shí)現(xiàn)

    希爾排序是希爾(Donald Shell)于1959年提出的一種排序算法。希爾排序也是一種插入排序,它是簡(jiǎn)單插入排序經(jīng)過(guò)改進(jìn)之后的一個(gè)更高效的版本,也稱(chēng)為縮小增量排序,同時(shí)該算法是沖破O(n2)的第一批算法之一。本文會(huì)以圖解的方式詳細(xì)介紹希爾排序的基本思想及其代碼實(shí)現(xiàn)
    2022-09-09
  • Java實(shí)現(xiàn)樹(shù)形菜單的方法總結(jié)

    Java實(shí)現(xiàn)樹(shù)形菜單的方法總結(jié)

    當(dāng)我們想要展示層級(jí)結(jié)構(gòu),如文件目錄、組織結(jié)構(gòu)或分類(lèi)目錄時(shí),樹(shù)形菜單是一個(gè)直觀且有效的解決方案,本文為大家整理了java中幾種常見(jiàn)方法,希望對(duì)大家有所幫助
    2023-08-08
  • 心動(dòng)嗎?正大光明的免費(fèi)使用IntelliJ IDEA商業(yè)版

    心動(dòng)嗎?正大光明的免費(fèi)使用IntelliJ IDEA商業(yè)版

    這篇文章主要介紹了正大光明的免費(fèi)使用IntelliJ IDEA商業(yè)版,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2020-02-02
  • 程序猿必須要掌握的多線程安全問(wèn)題之鎖策略詳解

    程序猿必須要掌握的多線程安全問(wèn)題之鎖策略詳解

    在筆者面試過(guò)程時(shí),經(jīng)常會(huì)被問(wèn)到各種各樣的鎖,如樂(lè)觀鎖、讀寫(xiě)鎖等等,非常繁多,在此做一個(gè)總結(jié),介紹的內(nèi)容如下,需要的朋友可以參考下
    2021-06-06
  • Java整合騰訊云短信發(fā)送實(shí)例代碼

    Java整合騰訊云短信發(fā)送實(shí)例代碼

    大家好,本篇文章主要講的是Java整合騰訊云短信發(fā)送實(shí)例代碼,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • java分類(lèi)樹(shù),我從2s優(yōu)化到0.1s

    java分類(lèi)樹(shù),我從2s優(yōu)化到0.1s

    這篇文章主要介紹了java分類(lèi)樹(shù),我從2s優(yōu)化到0.1s的相關(guān)資料,需要的朋友可以參考下
    2023-05-05

最新評(píng)論