logback使用filter過濾日志操作
筆者語錄: 我發(fā)現(xiàn)我喜歡搗鼓一些小玩意兒,雖然官網(wǎng)(見文末)寫得很明白了,但是咱們對感興趣的部分來敲一遍代碼好吧。
過濾器簡介:
簡介
logback具有過濾器支持。logbcak允許給日志記錄器appender配置一個或多個Filter(或者給整體配置一個或多個TurboFilter),來控制:當滿足過濾器指定的條件時,才記錄日志(或不滿足條件時,拒絕記錄日志)。logback支持自定義過濾器,當然logback也自帶了一些常用的過濾器,在絕大多數(shù)時候,自帶的過濾器其實就夠用了,一般是不需要自定義過濾器的。
logback提供的過濾器支持主要分兩大類
ch.qos.logback.core.filter.Filter
ch.qos.logback.classic.turbo.TurboFilter
過濾器 | 來源 | 說明 | 相對常用 |
---|---|---|---|
LevelFilter | Filter | 對指定level的日志進行記錄(或不記錄),對不等于指定level的日志不記錄(或進行記錄) | 是 |
ThresholdFilter | Filter | 對大于或等于指定level的日志進行記錄(或不記錄),對小于指定level的日志不記錄(或進行記錄) 提示:info級別是大于debug的 |
是 |
EvaluatorFilter | Filter | 對滿足指定表達式的日志進行記錄(或不記錄),對不滿足指定表達式的日志不作記錄(或進行記錄) | 是 |
MDCFilter | TurboFilter | 若MDC域中存在指定的key-value,則進行記錄,否者不作記錄 | 是 |
DuplicateMessageFilter | TurboFilter | 根據(jù)配置不記錄多余的重復的日志 | 是 |
MarkerFilter | TurboFilter | 針對帶有指定標記的日志,進行記錄(或不作記錄) | 否 |
… | … | … | … |
若過濾器已經(jīng)返回了需要記錄,那么就一定會對該日志進行記錄(不論當前日志的level是否大于等于系統(tǒng)設置的最低日志級別)。
TurboFilter的性能是優(yōu)于Filter的,這是因為TurboFilter的作用時機是在創(chuàng)建日志事件ILoggingEvent對象之前,而Filter的作用時機是在創(chuàng)建之后。若一個日志注定是會被過濾掉不記錄的,那么創(chuàng)建ILoggingEvent對象(包括后續(xù)的參數(shù)組裝方法調(diào)用等)這個步驟無疑是非常消耗性能的。
過濾器的FilterReply狀態(tài)枚舉:
對于Filter而言,需不需要記錄日志,取決于ch.qos.logback.core.filter.Filter#decide方法的返回:
Filter與TurboFilter自帶的幾種常用過濾器
對于TurboFilter而言,需不需要記錄日志,取決于ch.qos.logback.classic.turbo.TurboFilter#decide方法的返回:
可以看到,返回的都是FilterReply這個枚舉:
FilterReply有三種枚舉值:
DENY:表示不用看后面的過濾器了,這里就給拒絕了,不作記錄。
NEUTRAL:表示需不需要記錄,還需要看后面的過濾器。若所有過濾器返回的全部都是NEUTRAL,那么需要記錄日志。
ACCEPT:表示不用看后面的過濾器了,這里就給直接同意了,需要記錄。
過濾器的使用(示例):
使用LevelFilter的logback.xml(示例):
測試一下:
編寫測試方法:
運行方法,產(chǎn)出日志:
使用ThresholdFilter的logback.xml(示例):
測試一下:
編寫測試方法:
運行方法,產(chǎn)出日志:
使用EvaluatorFilter的logback.xml(示例):
需要引入額外的解析庫依賴janino:
<dependency> <groupId>org.codehaus.janino</groupId> <artifactId>janino</artifactId> <version>3.1.2</version> </dependency>
logbaxk.xml
測試一下:
編寫測試方法:
運行方法,產(chǎn)出日志:
使用MDCFilter的logback.xml(示例):
測試一下:
編寫測試方法:
運行方法,產(chǎn)出日志:
自定義過濾器:
自定義Filter:
編寫自定義Filter
在logback.xml中配置使用此過濾器
測試一下:
編寫測試方法:
運行方法,產(chǎn)出日志:
自定義TurboFilter:
編寫自定義TurboFilter
在logback.xml中配置使用此過濾器
測試一下:
編寫測試方法:
運行方法,產(chǎn)出日志:
logback使用filter過濾日志,初步學習完畢!
以上這篇logback使用filter過濾日志操作就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
IDEA?2022?中的Lombok?使用基礎(chǔ)教程
? Lombok是使用java編寫的一款開源類庫。其主作用是使用注解來代替一些具有格式固定,沒有過多技術(shù)含量的編碼工作,這篇文章主要介紹了IDEA?2022?中的Lombok?使用基礎(chǔ)教程,需要的朋友可以參考下2022-12-12flowable動態(tài)創(chuàng)建多級流程模板實現(xiàn)demo
這篇文章主要為大家介紹了flowable動態(tài)創(chuàng)建多級流程模板實現(xiàn)demo,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-05-05Spring Cloud Gateway 如何修改HTTP響應信息
這篇文章主要介紹了Spring Cloud Gateway 修改HTTP響應信息的方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07IntelliJ IDEA2021.1 配置大全(超詳細教程)
這篇文章主要介紹了IntelliJ IDEA2021.1 配置大全(超詳細教程),需要的朋友可以參考下2021-04-04SpringBoot項目中HTTP請求體只能讀一次的解決方案
在基于Spring開發(fā)Java項目時,可能需要重復讀取HTTP請求體中的數(shù)據(jù),例如使用攔截器打印入?yún)⑿畔⒌?但當我們重復調(diào)用getInputStream()或者getReader()時,通常會遇到SpringBoot HTTP請求只讀一次的問題,本文給出了幾種解決方案,需要的朋友可以參考下2024-08-08