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

Java中的MarkerFilter的應(yīng)用場景及使用示例詳解

 更新時(shí)間:2024年01月29日 09:23:03   作者:滴水可藏海  
這篇文章主要介紹了Java中的MarkerFilter的應(yīng)用場景及使用示例詳解,使用log4j2,負(fù)責(zé)從消息隊(duì)列收集日志的,現(xiàn)在系統(tǒng)收集到的日志能和這個(gè)系統(tǒng)本身的日志分開,需要的朋友可以參考下

背景

  • 有一個(gè)系統(tǒng)是負(fù)責(zé)從消息隊(duì)列收集日志的,現(xiàn)在系統(tǒng)收集到的日志能和這個(gè)系統(tǒng)本身的日志分開
  • 使用log4j2
 <!--log4j2依賴-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-log4j2</artifactId>
    <version>2.0.1.RELEASE</version>
</dependency>
<!-- Log4j2 異步支持 -->
<dependency>
    <groupId>com.lmax</groupId>
    <artifactId>disruptor</artifactId>
    <version>3.3.6</version>
</dependency>

解決方案

給我們需要的日志時(shí)間給一個(gè)特定的標(biāo)記(Marker),然后使用MarkerFilter來區(qū)分收集的日志與系統(tǒng)本身的日志

代碼

log4j2.xml配置示例

<?xml version="1.0" encoding="UTF-8"?>
<!-- Configuration后面的status,這個(gè)用于設(shè)置log4j2自身內(nèi)部的信息輸出,可以不設(shè)置,當(dāng)設(shè)置成trace時(shí),
 你會(huì)看到log4j2內(nèi)部各種詳細(xì)輸出。可以設(shè)置成OFF(關(guān)閉)或Error(只輸出錯(cuò)誤信息)
-->
<Configuration status="error" monitorInterval="60">
    <!-- 日志文件目錄和壓縮文件目錄配置 -->
    <Properties>
        <Property name="level">debug</Property>
        <Property name="fileName">./logs/test-program</Property>
        <Property name="fileGz">./logs/test-program</Property>
        <Property name="LOG_PATTERN">
            %d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level - %logger{36}.%M[%L] - %msg%xEx%n
        </Property>
    </Properties>
 
    <Appenders>
        <!-- 輸出控制臺(tái)日志的配置 -->
        <Console name="console" target="SYSTEM_OUT">
            <!--控制臺(tái)只輸出level及以上級別的信息(onMatch),其他的直接拒絕(onMismatch)-->
            <ThresholdFilter level="ERROR" onMatch="ACCEPT" onMismatch="DENY"/>
            <!-- 輸出日志的格式 -->
            <PatternLayout pattern="${LOG_PATTERN}"/>
        </Console>
 
        <!-- 打印出所有的信息,每次大小超過size,則這size大小的日志會(huì)自動(dòng)存入按年份-月份建立的文件夾下面并進(jìn)行壓縮,作為存檔 -->
        <RollingRandomAccessFile name="appLogAppender" fileName="${fileName}/app.log" immediateFlush="false"
                                 filePattern="${fileGz}/$${date:yyyy-MM}/app-%d{MM-dd-yyyy}-%i.gz">
            <PatternLayout pattern="${LOG_PATTERN}"/>
            <Policies>
                <TimeBasedTriggeringPolicy interval="6" modulate="true"/>
                <SizeBasedTriggeringPolicy size="100 MB"/>
            </Policies>
            <Filters>
            	<!--如果日志事件LogEvent中有COLLECTED標(biāo)記,則直接拒絕這個(gè)日志事件-->
                <MarkerFilter marker="COLLECTED" onMatch="DENY" onMismatch="NEUTRAL"/>
                <!--如果日志事件LogEvent中的日志等級為${level}及以上,則接受這個(gè)日志事件-->
                <ThresholdFilter level="${level" onMatch="ACCEPT" onMismatch="DENY"/>
            </Filters>
            <!-- 指定每天的最大壓縮包個(gè)數(shù),默認(rèn)7個(gè),超過了會(huì)覆蓋之前的 -->
            <DefaultRolloverStrategy max="10"/>
        </RollingRandomAccessFile>
 
        <!-- 打印出所有的信息,每次大小超過size,則這size大小的日志會(huì)自動(dòng)存入按年份-月份建立的文件夾下面并進(jìn)行壓縮,作為存檔 -->
        <RollingRandomAccessFile name="collectedLogAppender" fileName="${fileName}/collected.log" immediateFlush="false"
                                 filePattern="${fileGz}/$${date:yyyy-MM}/collected-%d{MM-dd-yyyy}-%i.gz">
            <PatternLayout pattern="%msg%xEx%n"/>
            <Policies>
                <TimeBasedTriggeringPolicy interval="6" modulate="true"/>
                <SizeBasedTriggeringPolicy size="500 MB"/>
            </Policies>
            <Filters>
                <!--如果日志事件LogEvent中有COLLECTED標(biāo)記,則繼續(xù)走接下來的filter,如果接下來沒有其他的filter,onMatch的動(dòng)作填A(yù)CCEPT就好了-->
                <MarkerFilter marker="COLLECTED" onMatch="NEUTRAL" onMismatch="DENY"/>
                <ThresholdFilter level="${level" onMatch="ACCEPT" onMismatch="DENY"/>
            </Filters>
            <!-- 指定每天的最大壓縮包個(gè)數(shù),默認(rèn)7個(gè),超過了會(huì)覆蓋之前的 -->
           <DefaultRolloverStrategy max="1000"/>
        </RollingRandomAccessFile>
 
    </Appenders>
 
    <!-- 全局配置,默認(rèn)所有的Logger都繼承此配置 -->
    <Loggers>
        <Root level="${level}" additivity="false" includeLocation="true">
            <AppenderRef ref="collectedLogAppender"/>
            <AppenderRef ref="appLogAppender"/>
            <AppenderRef ref="console"/>
        </Root>
    </Loggers>
</Configuration>

代碼示例

//需要引入lombok的依賴
import lombok.extern.slf4j.Slf4j;
//這里包名容易搞錯(cuò),需要特別注意
import org.slf4j.Marker;
import org.slf4j.MarkerFactory;
import org.slf4j.Marker;
 
@Slf4j
public class LogCollector {
    private static final Marker COLLECTED_MARKER = MarkerFactory.getMarker("test_marker");
 
    public static void main(String[] args) {
        log.info(COLLECTED_MARKER,  "Test message~");
   }
}

結(jié)果

可以發(fā)現(xiàn)在./logs/test-program目錄下,有兩個(gè)日志文件:

  • 一個(gè)只有收集到的日志:collected.log
  • 一個(gè)只有系統(tǒng)日志: app.log

到此這篇關(guān)于Java中的MarkerFilter的應(yīng)用場景及使用示例詳解的文章就介紹到這了,更多相關(guān)MarkerFilter應(yīng)用場景及使用示例內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 大數(shù)組元素差異removeAll與Map效率對比

    大數(shù)組元素差異removeAll與Map效率對比

    這篇文章主要介紹了大數(shù)組元素差異removeAll與Map效率對比,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-03-03
  • javax NotBlank和Email注解失效的解決

    javax NotBlank和Email注解失效的解決

    這篇文章主要介紹了javax NotBlank和Email注解失效的解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • MyBatis自定義TypeHandler實(shí)現(xiàn)字段加密解密

    MyBatis自定義TypeHandler實(shí)現(xiàn)字段加密解密

    本文主要介紹了MyBatis自定義TypeHandler實(shí)現(xiàn)字段加密解密,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2025-03-03
  • java中set接口使用方法詳解

    java中set接口使用方法詳解

    這篇文章主要為大家詳細(xì)介紹了java中set接口使用方法,介紹了Java中Set集合接口實(shí)現(xiàn)插入對象不重復(fù)的原理,感興趣的小伙伴們可以參考一下
    2016-05-05
  • Gson中@JsonAdater注解的幾種方式總結(jié)

    Gson中@JsonAdater注解的幾種方式總結(jié)

    這篇文章主要介紹了Gson中@JsonAdater注解的幾種方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • kafka運(yùn)維consumer-groups.sh消費(fèi)者組管理

    kafka運(yùn)維consumer-groups.sh消費(fèi)者組管理

    這篇文章主要為大家介紹了kafka運(yùn)維consumer-groups.sh消費(fèi)者組管理,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • 全面理解java中的構(gòu)造方法以及this關(guān)鍵字的用法

    全面理解java中的構(gòu)造方法以及this關(guān)鍵字的用法

    本篇文章主要概述了如何用構(gòu)造方法初始化對象,this屬性名訪問成員變量方法,和this()的用法,感興趣的小伙伴一起來學(xué)習(xí)吧
    2023-03-03
  • 關(guān)于Java父類沒有無參構(gòu)造方法子類處理方法

    關(guān)于Java父類沒有無參構(gòu)造方法子類處理方法

    父類無參構(gòu)造方法,子類不寫,其實(shí)會(huì)默認(rèn)調(diào)用父類的無參構(gòu)造方法也就是用super(),編譯運(yùn)行后,會(huì)打印出"子類會(huì)調(diào)用Father的第一個(gè)構(gòu)造方法,這篇文章給大家介紹關(guān)于Java父類沒有無參構(gòu)造方法子類處理方法,感興趣的朋友一起看看吧
    2024-01-01
  • Java設(shè)計(jì)模式之裝飾模式詳解

    Java設(shè)計(jì)模式之裝飾模式詳解

    這篇文章主要介紹了Java設(shè)計(jì)模式之裝飾模式詳解,文中有非常詳細(xì)的代碼示例,對正在學(xué)習(xí)java的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2021-04-04
  • JDK集合源碼之解析TreeMap(二)

    JDK集合源碼之解析TreeMap(二)

    下面小編就為大家?guī)硪黄獪\談java中的TreeMap 排序與TreeSet 排序。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2021-07-07

最新評論