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)文章
Java實(shí)現(xiàn)畫線、矩形、橢圓、字符串功能
本篇文章主要介紹了Java實(shí)現(xiàn)畫線、矩形、橢圓、字符串功能的實(shí)例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-05-05Spring Boot讀取resources目錄文件方法詳解
這篇文章主要介紹了Spring Boot讀取resources目錄文件方法詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-01-01Java實(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