国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > Java > 正文

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

2024-07-13 10:14:56
字體:
來源:轉載
供稿:網友

在使用Spring框架的時候,我們可以很方便的配置log4j來進行日志管理。

Spring 5.0發布一段時間了,最近將項目從Spring 4.3升級到Spring 5.0,Spring 4.3集成log4j所用的類org.springframework.web.util.Log4jConfigListener在Spring 5.0版本已經刪除,而且log4j 1.x版已經不再更新。我們將log4j-1.x升級為log4j-2.x

先引入log4j 2的三個jar包

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

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

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

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

在項目的src目錄下加入log4j2.properties文件,spring 5.0默認會自動加載該文件

# 設定Log4j2內部的日志級別,有效值:trace, debug, info, warn, error, fatal。只對Log4j本身的事件有效,可以不設置,當設置成trace時,會看到log4j2內部各種詳細輸出status = fatal# 配置的名稱name =PropertiesConfigappenders = console,I#控制臺類型的日志輸出源appender.console.type = Console#輸出源的名稱appender.console.name = consoleLog#輸出布局類型appender.console.layout.type = PatternLayout#輸出模板appender.console.layout.pattern = %m%nappender.console.target = System_out # 文件滾動記錄類型的日志輸出源appender.I.type = RollingFile# 當前滾動輸出源的名稱,以便在Logger的配置項中能夠調用appender.I.name = InfoRollingFile# 當前正在操作的日志文件的文件名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# 基于時間進行日志的切割appender.I.policies.time.type = TimeBasedTriggeringPolicy# 切割的間隔為1月, 即每天進行一次日志的歸檔,如果filePattern中配置的文件重命名規則是${web:rootDir}/WEB-INF/log/info_%d{yyyy-MM-dd HH-mm}-%i,最小的時間粒度是mm,即分鐘,TimeBasedTriggeringPolicy指定的size是1,結合起來就是每2分鐘生成一個新文件。如果改成%d{yyyy-MM-dd HH},最小粒度為小時,則每2個小時生成一個文件。appender.I.policies.time.interval = 1# 修正時間范圍, 從0時開始計數。若modulate=true,則封存時間將以0點為邊界進行偏移計算。比如,modulate=true,interval=4hours,那么假設上次封存日志的時間為03:00,則下次封存日志的時間為04:00,之后的封存時間appender.I.policies.time.modulate = true# 基于日志文件體積的觸發策略appender.I.policies.size.type = SizeBasedTriggeringPolicy# 當日志文件體積大于size指定的值時,觸發Rollingappender.I.policies.size.size=50M# 文件封存的覆蓋策略(RolloverStrategy)appender.I.strategy.type = DefaultRolloverStrategy# 生成分割(封存)文件的個數appender.I.strategy.max = 100# 根日志,所有日志的父節點 級別順序(低到高):all < trace <debug < info < warn < error < fatal <offrootLogger.level = debugrootLogger.appenderRef.I.ref = InfoRollingFilerootLogger.appenderRef.I.level = info# 關聯名稱為consoleLog的輸出源 注意consolelog小寫rootLogger.appenderRef.consolelog.ref = consoleLog# 生產環境設為off關閉控制臺日志輸出rootLogger.appenderRef.consolelog.level = debug

配置完成后寫個類測試一下

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 贵港市| 伊金霍洛旗| 淄博市| 临城县| 鹰潭市| 五台县| 龙口市| 察哈| 华宁县| 韩城市| 富锦市| 乐昌市| 布尔津县| 苍梧县| 贞丰县| 改则县| 务川| 双辽市| 库伦旗| 铅山县| 岱山县| 伊春市| 石嘴山市| 屏东市| 湖北省| 彭阳县| 塔河县| 邻水| 滦南县| 商水县| 贡嘎县| 东乡族自治县| 平利县| 天全县| 烟台市| 额敏县| 沧源| 黑山县| 嫩江县| 吉安县| 察隅县|