logback使用filter過(guò)濾日志操作
筆者語(yǔ)錄: 我發(fā)現(xiàn)我喜歡搗鼓一些小玩意兒,雖然官網(wǎng)(見文末)寫得很明白了,但是咱們對(duì)感興趣的部分來(lái)敲一遍代碼好吧。
過(guò)濾器簡(jiǎn)介:
簡(jiǎn)介
logback具有過(guò)濾器支持。logbcak允許給日志記錄器appender配置一個(gè)或多個(gè)Filter(或者給整體配置一個(gè)或多個(gè)TurboFilter),來(lái)控制:當(dāng)滿足過(guò)濾器指定的條件時(shí),才記錄日志(或不滿足條件時(shí),拒絕記錄日志)。logback支持自定義過(guò)濾器,當(dāng)然logback也自帶了一些常用的過(guò)濾器,在絕大多數(shù)時(shí)候,自帶的過(guò)濾器其實(shí)就夠用了,一般是不需要自定義過(guò)濾器的。
logback提供的過(guò)濾器支持主要分兩大類
ch.qos.logback.core.filter.Filter

ch.qos.logback.classic.turbo.TurboFilter

| 過(guò)濾器 | 來(lái)源 | 說(shuō)明 | 相對(duì)常用 |
|---|---|---|---|
| LevelFilter | Filter | 對(duì)指定level的日志進(jìn)行記錄(或不記錄),對(duì)不等于指定level的日志不記錄(或進(jìn)行記錄) | 是 |
| ThresholdFilter | Filter | 對(duì)大于或等于指定level的日志進(jìn)行記錄(或不記錄),對(duì)小于指定level的日志不記錄(或進(jìn)行記錄) 提示:info級(jí)別是大于debug的 |
是 |
| EvaluatorFilter | Filter | 對(duì)滿足指定表達(dá)式的日志進(jìn)行記錄(或不記錄),對(duì)不滿足指定表達(dá)式的日志不作記錄(或進(jìn)行記錄) | 是 |
| MDCFilter | TurboFilter | 若MDC域中存在指定的key-value,則進(jìn)行記錄,否者不作記錄 | 是 |
| DuplicateMessageFilter | TurboFilter | 根據(jù)配置不記錄多余的重復(fù)的日志 | 是 |
| MarkerFilter | TurboFilter | 針對(duì)帶有指定標(biāo)記的日志,進(jìn)行記錄(或不作記錄) | 否 |
| … | … | … | … |
若過(guò)濾器已經(jīng)返回了需要記錄,那么就一定會(huì)對(duì)該日志進(jìn)行記錄(不論當(dāng)前日志的level是否大于等于系統(tǒng)設(shè)置的最低日志級(jí)別)。
TurboFilter的性能是優(yōu)于Filter的,這是因?yàn)門urboFilter的作用時(shí)機(jī)是在創(chuàng)建日志事件ILoggingEvent對(duì)象之前,而Filter的作用時(shí)機(jī)是在創(chuàng)建之后。若一個(gè)日志注定是會(huì)被過(guò)濾掉不記錄的,那么創(chuàng)建ILoggingEvent對(duì)象(包括后續(xù)的參數(shù)組裝方法調(diào)用等)這個(gè)步驟無(wú)疑是非常消耗性能的。
過(guò)濾器的FilterReply狀態(tài)枚舉:
對(duì)于Filter而言,需不需要記錄日志,取決于ch.qos.logback.core.filter.Filter#decide方法的返回:

Filter與TurboFilter自帶的幾種常用過(guò)濾器
對(duì)于TurboFilter而言,需不需要記錄日志,取決于ch.qos.logback.classic.turbo.TurboFilter#decide方法的返回:

可以看到,返回的都是FilterReply這個(gè)枚舉:

FilterReply有三種枚舉值:
DENY:表示不用看后面的過(guò)濾器了,這里就給拒絕了,不作記錄。
NEUTRAL:表示需不需要記錄,還需要看后面的過(guò)濾器。若所有過(guò)濾器返回的全部都是NEUTRAL,那么需要記錄日志。
ACCEPT:表示不用看后面的過(guò)濾器了,這里就給直接同意了,需要記錄。
過(guò)濾器的使用(示例):
使用LevelFilter的logback.xml(示例):

測(cè)試一下:
編寫測(cè)試方法:

運(yùn)行方法,產(chǎn)出日志:

使用ThresholdFilter的logback.xml(示例):

測(cè)試一下:
編寫測(cè)試方法:

運(yùn)行方法,產(chǎn)出日志:

使用EvaluatorFilter的logback.xml(示例):
需要引入額外的解析庫(kù)依賴janino:
<dependency> <groupId>org.codehaus.janino</groupId> <artifactId>janino</artifactId> <version>3.1.2</version> </dependency>
logbaxk.xml

測(cè)試一下:
編寫測(cè)試方法:

運(yùn)行方法,產(chǎn)出日志:

使用MDCFilter的logback.xml(示例):
測(cè)試一下:

編寫測(cè)試方法:

運(yùn)行方法,產(chǎn)出日志:

自定義過(guò)濾器:
自定義Filter:
編寫自定義Filter

在logback.xml中配置使用此過(guò)濾器

測(cè)試一下:
編寫測(cè)試方法:

運(yùn)行方法,產(chǎn)出日志:

自定義TurboFilter:
編寫自定義TurboFilter

在logback.xml中配置使用此過(guò)濾器

測(cè)試一下:
編寫測(cè)試方法:

運(yùn)行方法,產(chǎn)出日志:

logback使用filter過(guò)濾日志,初步學(xué)習(xí)完畢!
以上這篇logback使用filter過(guò)濾日志操作就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
java學(xué)習(xí)筆記之eclipse+tomcat 配置
俗話說(shuō):工欲善其事必先利其器,既然要學(xué)習(xí)java,首先把java的開發(fā)環(huán)境搗鼓一下吧,這里我們來(lái)談?wù)別clipse+tomcat的配置方法。2014-11-11
idea2020.2卡死在reading maven projects
這篇文章主要介紹了idea2020.2卡死在reading maven projects,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09
SpringBoot如何使用@Aspect注解實(shí)現(xiàn)AOP
這篇文章主要介紹了SpringBoot如何使用@Aspect注解實(shí)現(xiàn)AOP問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07

