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

log4j2使用filter過濾日志方式

 更新時間:2021年12月24日 10:59:50   作者:justry_deng  
這篇文章主要介紹了log4j2使用filter過濾日志方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

背景說明

log4j2作為log4j的升級版本,其性能自然是大大優(yōu)于log4j的,同時其其性能又是優(yōu)于logback的,甚至在部分領(lǐng)域,log4j2的性能遠(yuǎn)超logback幾個數(shù)量級。 ??

log4j2的亮點(diǎn)主要在這幾個方法進(jìn)行體現(xiàn):異步、并發(fā)、配置優(yōu)化、插件機(jī)制等。本文初步學(xué)習(xí)基于log4j2插件機(jī)制的Filter。

Filter.Result的三種過濾結(jié)果

log4j2走過濾器的邏輯后,會返回對應(yīng)的過濾Result結(jié)果,以控制是否記錄日志、怎樣記錄日志。過濾器的結(jié)果有:

在這里插入圖片描述

  • ACCEPT:(不需要再走后面的過濾器了,)需要記錄當(dāng)前日志。
  • NEUTRAL:需不需要記錄當(dāng)前日志,由后續(xù)過濾器決定。若所有過濾器返回的結(jié)果都是NEUTRAL,那么需要記錄日志。
  • DENY:(不需要再走后面的過濾器了,)不需要記錄當(dāng)前日志。

提示:log4j2的此機(jī)制與logback是一樣的。

log4j2提供的過濾器(功能簡述)

提示: 下圖基于log4j2.13.3。

在這里插入圖片描述

過濾器 說明 是否常用
StringMatchFilter 如果格式化后(即:最終)的日志信息中包含${指定的字符串},則onMatch,否則onMismatch 即: msg.contains(this.text) ? onMatch : onMismatch;
LevelRangeFilter 若${maxLevel} <= 日志級別 <= ${minLevel}, 則onMatch,否則onMismatch 如: 即為只記錄日志info及warn級別的日志。
RegexFilter 如果日志信息匹配${指定的正則表達(dá)式},則onMatch,否則onMismatch 注:可通過useRawMsg屬性來控制這個日志信息是格式化處理后(即:最終)的日志信息,還是格式化處理前(即:代碼中輸入)的日志信息。
ThresholdFilter 若日志級別 >= ${指定的日志級別}, 則onMatch,否則onMismatch
LevelMatchFilter 如果日志級別等于${指定的日志級別},則onMatch,否則onMismatch
ThreadContextMapFilter 通過context(可以理解為一個Map)中對應(yīng)的key-value值進(jìn)行過濾 注:上下文默認(rèn)是ThreadContext,也可以自定義使用ContextDataInjectorFactory配置ContextDataInjector來指定。
DynamicThresholdFilter 若上下文中包含指定的key,則觸發(fā)DynamicThresholdFilter生效;若該key對應(yīng)的value值等于任意一個我們指定的值,那么針對本條日志,可記錄日志級別的約束下限調(diào)整為指定的級別 注:上下文默認(rèn)是ThreadContext,也可以自定義使用ContextDataInjectorFactory配置ContextDataInjector來指定。 示例說明:<DynamicThresholdFilter key="loginRole" defaultThreshold="ERROR" onMatch="ACCEPT" onMismatch="NEUTRAL"><KeyValuePair key="admin" value="DEBUG"/><KeyValuePair key="user" value="warn"/></DynamicThresholdFilter>配置,有以下情況: 情況一:存在鍵loginRole,假設(shè)從上下文(可以理解為一個Map)中取出來的對應(yīng)的值為user,那么此時,對于日志級別大于等于warn的日志,會走onMatch;其它的日志級別走onMismatch。 情況二:存在鍵loginRole,假設(shè)從context(可以理解為一個Map)中取出來的對應(yīng)的值為admin,那么此時,對于日志級別大于等于debug的日志,會走onMatch;其它的日志級別走onMismatch。 情況三:【上下文(可以理解為一個Map)中,不存在鍵loginRole】或【存在鍵loginRole,但從日志上下文中取出來的值(假設(shè))為abc, 沒有對應(yīng)的KeyValuePair配置】,那么此時<DynamicThresholdFilter key="userRole" defaultThreshold="AAA" onMatch="BBB" onMismatch="CCC">等價于<LevelMatchFilter level="AAA" onMatch="BBB" onMismatch="CCC">。
CompositeFilter 組合過濾器,即:按照xml配置中的配置,一個過濾器一個過濾器的走,如果在這過程中,任意一個過濾器ACCEPT或DENY了,那么就不會往后走了,直接返回對應(yīng)的結(jié)果。
TimeFilter 如果記錄日志時的當(dāng)前時間落在每天指定的時間范圍[start, end]內(nèi),則onMatch,否則onMismatch 如:<TimeFilter start="05:00:00" end="05:30:00" onMatch="ACCEPT" onMismatch="DENY"/>。
ScriptFilter 是否匹配取決于指定的腳本返回值是否為true
DenyAllFilter This filter causes all logging events to be dropped
BurstFilter 對低于或等于${指定日志級別}的日志,進(jìn)行限流控制
NoMarkerFilter 如果從對應(yīng)事件對象獲取(LogEvent#getMarker)到的marker為null, 則onMatch,否則onMismatch
MarkerFilter 如果從對應(yīng)事件對象獲取(LogEvent#getMarker)到的marker的name值為等于${指定的值}, 則onMatch,否則onMismatch
MapFilter The MapFilter allows filtering against data elements that are in a MapMessage. 注:需要使用org.apache.logging.log4j.Logger進(jìn)行記錄,且記錄org.apache.logging.log4j.message.MapMessage日志,才會生效。 注:因?yàn)闀簳r不兼容Slf4j這里不多作說明
StructuredDataFilter The StructuredDataFilter is a MapFilter that also allows filtering on the event id, type and message. 注:需要使用org.apache.logging.log4j.Logger進(jìn)行記錄,且記錄org.apache.logging.log4j.core.filter.StructuredDataFilter日志,才會生效。 注:因?yàn)闀簳r不兼容Slf4j這里不多作說明

Filter的作用范圍

log4j2在處理日志時,各個Filter會組成過濾鏈,越靠前的Filter越先過濾,自然影響范圍就越大。在log4j2的xml配置文件中,F(xiàn)ilter可以配置在四個位置,由全局到局部依次是 Context-wide、 Logger和Appender、AppenderReference, 圖示說明:

在這里插入圖片描述

常用過濾器使用示例(文字版代碼見文末鏈接)

StringMatchFilter

log4j2.xml配置

在這里插入圖片描述

測試代碼與輸出日志

在這里插入圖片描述

LevelRangeFilter

log4j2.xml配置

在這里插入圖片描述

測試代碼與輸出日志

在這里插入圖片描述

RegexFilter

log4j2.xml配置

在這里插入圖片描述

測試代碼與輸出日志

在這里插入圖片描述

ThresholdFilter

log4j2.xml配置

在這里插入圖片描述

測試代碼與輸出日志

在這里插入圖片描述

LevelMatchFilter

log4j2.xml配置

在這里插入圖片描述

測試代碼與輸出日志

在這里插入圖片描述

ThreadContextMapFilter

示例一: log4j2.xml配置

在這里插入圖片描述

測試代碼與輸出日志

在這里插入圖片描述

示例二: log4j2.xml配置

在這里插入圖片描述

測試代碼與輸出日志

在這里插入圖片描述

DynamicThresholdFilter

log4j2.xml配置

在這里插入圖片描述

測試代碼與輸出日志

在這里插入圖片描述

CompositeFilter

log4j2.xml配置

在這里插入圖片描述

測試代碼與輸出日志

在這里插入圖片描述

自定義Filter

一般來說,log4j2官方提供的過濾器就足夠我們使用了,如果非要自定義過濾器,可以繼承AbstractFilter,或者直接實(shí)現(xiàn)Filter,這里不再演示自定義過濾器。

更多可見:

https://logging.apache.org/log4j/2.x/manual/filters.html

http://logging.apache.org/log4j/2.x/log4j-core/apidocs/org/apache/logging/log4j/core/filter/

以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • maven之packaging標(biāo)簽的使用

    maven之packaging標(biāo)簽的使用

    這篇文章主要介紹了maven之packaging標(biāo)簽的使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • RPC框架之Thrift的入門教程

    RPC框架之Thrift的入門教程

    Thrift是一個跨語言的服務(wù)部署框架,主要用于各個服務(wù)之間的RPC通信,支持跨語言,下面小編就來和大家講講Thrift框架的具體使用,希望對大家有所幫助
    2023-10-10
  • Java實(shí)現(xiàn)畫線、矩形、橢圓、字符串功能

    Java實(shí)現(xiàn)畫線、矩形、橢圓、字符串功能

    本篇文章主要介紹了Java實(shí)現(xiàn)畫線、矩形、橢圓、字符串功能的實(shí)例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • Java集合List相關(guān)面試題整理大全

    Java集合List相關(guān)面試題整理大全

    這篇文章主要給大家介紹了關(guān)于Java集合List相關(guān)面試題整理的相關(guān)資料,下面將提供一些常見的Java集合類面試題及其解答,幫助讀者更好地準(zhǔn)備面試,需要的朋友可以參考下
    2024-01-01
  • 十分鐘理解Java中的動態(tài)代理

    十分鐘理解Java中的動態(tài)代理

    十分鐘幫助大家理解Java中的動態(tài)代理,什么是動態(tài)代理?感興趣的小伙伴們可以參考一下
    2016-06-06
  • Spring Boot讀取resources目錄文件方法詳解

    Spring Boot讀取resources目錄文件方法詳解

    這篇文章主要介紹了Spring Boot讀取resources目錄文件方法詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-01-01
  • Springboot中yml對于list列表配置方式詳解

    Springboot中yml對于list列表配置方式詳解

    這篇文章主要介紹了Springboot中yml對于list列表配置方式詳解,使用@ConfigurationProperties讀取yml配置文件過程中會遇到讀取yml文件中列表,Config里面使用List集合接收,方法比較簡單,需要的朋友可以參考下
    2023-11-11
  • java中獲取hashmap中的所有key方式

    java中獲取hashmap中的所有key方式

    這篇文章主要介紹了java中獲取hashmap中的所有key方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • 聊聊SpringBoot自動裝配的魔力

    聊聊SpringBoot自動裝配的魔力

    這篇文章主要介紹了SpringBoot自動裝配的魔力,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • Java實(shí)現(xiàn)BP神經(jīng)網(wǎng)絡(luò)MNIST手寫數(shù)字識別的示例詳解

    Java實(shí)現(xiàn)BP神經(jīng)網(wǎng)絡(luò)MNIST手寫數(shù)字識別的示例詳解

    這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)BP神經(jīng)網(wǎng)絡(luò)MNIST手寫數(shù)字識別的相關(guān)方法,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起了解一下
    2023-01-01

最新評論