亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在Springboot2.x 中利用Log4j2 異步打印日志

發布時間:2020-12-29 14:01:35 來源:億速云 閱讀:403 作者:Leah 欄目:開發技術

本篇文章為大家展示了怎么在Springboot2.x 中利用Log4j2 異步打印日志,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

1、pom 準備

1.1、war 包 web 工程

<dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-web</artifactId>
 <exclusions>
  <!--排除 springboot 默認的 logback 依賴 -->
  <exclusion>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-logging</artifactId>
  </exclusion>
 </exclusions>
</dependency>
<!--引入 log4j2-->
<dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-log4j2</artifactId>
 <version>2.2.6.RELEASE</version>
</dependency>
<!--異步,使用 log4j2 的 AsyncLogger 時需要包含 disruptor-->
<dependency>
 <groupId>com.lmax</groupId>
 <artifactId>disruptor</artifactId>
 <version>3.4.2</version>
</dependency>

1.2、jar 包自啟動工程

<dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter</artifactId>
 <exclusions>
  <!--排除 springboot 默認的 logback 依賴 -->
  <exclusion>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-logging</artifactId>
  </exclusion>
 </exclusions>
</dependency>
<!--引入 log4j2-->
<dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-log4j2</artifactId>
 <version>2.2.6.RELEASE</version>
</dependency>
<!--異步,使用 log4j2 的 AsyncLogger 時需要包含 disruptor-->
<dependency>
 <groupId>com.lmax</groupId>
 <artifactId>disruptor</artifactId>
 <version>3.4.2</version>
</dependency>

2、application.yml 配置

# 引入日志配置文件
logging:
 config: classpath:log4j2.xml

3、log4j2.xml 配置

classpath:log4j2.xml 的話,log4j2.xml 放在目錄 resources 下即可

<?xml version="1.0" encoding="UTF-8"?>
<!--Configuration 后面的 status,這個用于設置 log4j2 自身內部的信息輸出級別,可以不設置,當設置成 trace 時,你會看到 log4j2 內部各種詳細輸出-->
<!--monitorInterval:Log4j2 能夠自動檢測修改配置 文件和重新配置本身,設置間隔秒數-->
<configuration status="error" monitorInterval="30">
 <!--日志級別以及優先級排序: OFF > FATAL > ERROR > WARN > INFO > DEBUG > TRACE > ALL -->

 <!--變量配置-->
 <Properties>
  <!-- 格式化輸出:%date 表示日期,%thread 表示線程名,%-5level:級別從左顯示 5 個字符寬度 %msg:日志消息,%n 是換行符-->
  <!-- %logger{36} 表示 Logger 名字最長 36 個字符 -->
  <property name="LOG_PATTERN" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level [%logger{50}:%L] - %msg%n" />
  <!-- 定義日志存儲的路徑 -->
  <property name="FILE_PATH" value="/var/log/songo" />
  <property name="FILE_NAME" value="songo" />
 </Properties>

 <appenders>

  <console name="Console" target="SYSTEM_OUT">
   <!--輸出日志的格式-->
   <PatternLayout pattern="${LOG_PATTERN}" charset="UTF-8"/>
  </console>

  <!-- 這個會打印出所有的info及以上級別的信息,每次大小超過size,則這size大小的日志會自動存入按年份-月份建立的文件夾下面并進行壓縮,作為存檔-->
  <RollingFile name="RollingFileInfo" fileName="${FILE_PATH}/${FILE_NAME}/${FILE_NAME}.log" filePattern="${FILE_PATH}/${FILE_NAME}/${FILE_NAME}-INFO-%d{yyyy-MM-dd}_%i.log.gz" append="true">
   <PatternLayout pattern="${LOG_PATTERN}" charset="UTF-8"/>
   <Policies>
    <!-- 基于時間的觸發策略。該策略主要是完成周期性的log文件封存工作。有兩個參數:
    interval,integer型,指定兩次封存動作之間的時間間隔。單位:以日志的命名精度來確定單位,
     比如yyyy-MM-dd-HH 單位為小時,yyyy-MM-dd-HH-mm 單位為分鐘
    modulate,boolean型,說明是否對封存時間進行調制。若modulate=true,
     則封存時間將以0點為邊界進行偏移計算。比如,modulate=true,interval=4hours,
     那么假設上次封存日志的時間為00:00,則下次封存日志的時間為04:00,
     之后的封存時間依次為08:00,12:00,16:00-->
    <TimeBasedTriggeringPolicy interval="1"/>
    <SizeBasedTriggeringPolicy size="10MB"/>
   </Policies>
   <!-- DefaultRolloverStrategy 屬性如不設置,則默認為最多同一文件夾下當天 7 個文件后開始覆蓋-->
   <DefaultRolloverStrategy max="30">
    <!-- 刪除處理策略,在配置的路徑中搜索,maxDepth 表示往下搜索的最大深度 -->
    <Delete basePath="${FILE_PATH}/${FILE_NAME}/" maxDepth="2">
     <!-- 文件名搜索匹配,支持正則 -->
     <IfFileName glob="*.log.gz" />
     <!--!Note: 這里的 age 必須和 filePattern 協調, 后者是精確到 dd, 這里就要寫成 xd, xD 就不起作用
     另外, 數字最好 >2, 否則可能造成刪除的時候, 最近的文件還處于被占用狀態,導致刪除不成功!-->
     <!--7天-->
     <IfLastModified age="7d" />
    </Delete>
   </DefaultRolloverStrategy>
  </RollingFile>
 </appenders>

 <!--Logger 節點用來單獨指定日志的形式,比如要為指定包下的 class 指定不同的日志級別等。-->
 <!--然后定義 loggers,只有定義了 logger 并引入的 appender,appender 才會生效-->
 <loggers>
  <!--若是 additivity 設為 false,則子 Logger 只會在自己的 appender 里輸出,而不會在父 Logger 的 appender 里輸出。-->
  <!--Console、RollingFileInfo 沒有配置 ThresholdFilter,默認走的是 AsyncRoot 的 level 級別,
   com.songo.mapper 為我項目 mapper 的包路徑,級別設為 debug,可以打印 sql 語句-->
  <AsyncLogger name="com.songo.mapper" level="debug" additivity="false">
   <appender-ref ref="Console"/>
   <appender-ref ref="RollingFileInfo"/>
  </AsyncLogger>
  <AsyncLogger name="org.springframework" level="warn" additivity="false">
   <appender-ref ref="Console"/>
   <appender-ref ref="RollingFileInfo"/>
  </AsyncLogger>
  <AsyncRoot level="info" includeLocation="true">
   <AppenderRef ref="Console"/>
   <AppenderRef ref="RollingFileInfo" />
  </AsyncRoot>
 </loggers>
</configuration>

4、使用

4.1、聲明 logger 變量

package com.songo.service;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class TestService {
 private static final Logger logger = LoggerFactory.getLogger(TestService.class);
 
 public void Test() {
  logger.info("test...");
 }
}

4.2、簡單點 lombok
引入 pom

<dependency>
 <groupId>org.projectlombok</groupId>
 <artifactId>lombok</artifactId>
 <scope>provided</scope>
</dependency>
package com.songo.service;

import lombok.extern.slf4j.Slf4j;

@Slf4j
public class TestService {

 public void Test() {
  log.info("test...");
 }
}

5、驗證

服務啟動時,找到 log4j2 的線程,是如下內容說明 log4j2 異步日志打印配置成功

怎么在Springboot2.x 中利用Log4j2 異步打印日志

上述內容就是怎么在Springboot2.x 中利用Log4j2 異步打印日志,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

六枝特区| 闽清县| 常宁市| 娄底市| 吴堡县| 子洲县| 什邡市| 夏津县| 广灵县| 广南县| 巢湖市| 阿城市| 荥经县| 安国市| 南昌市| 新化县| 托里县| 黎川县| 博罗县| 威远县| 美姑县| 全南县| 天长市| 凌海市| 西乌珠穆沁旗| 噶尔县| 奎屯市| 花莲市| 桃园县| 宜君县| 自治县| 永平县| 隆昌县| 江阴市| 双江| 五河县| 旅游| 淳化县| 金乡县| 乐平市| 惠来县|