Java中的logback標記日志過濾器MarkerFilter詳解
開源日志SDK(純java版)
<!-- Java基于logback的日志組件SDK -->
<dependency>
<groupId>io.github.mingyang66</groupId>
<artifactId>emily-spring-boot-logger</artifactId>
<version>4.3.6</version>
</dependency>
<!--Java通用日志組件SDK-->
<dependency>
<groupId>io.github.mingyang66</groupId>
<artifactId>oceansky-logger</artifactId>
<version>4.3.6</version>
</dependency>
在logback-classic中存在一個全局過濾器TurboFilter,TurboFilter是與LoggerContext綁定,會在會在其它過濾器之前執(zhí)行;MarkerFilter是TurboFilter的一個子類,其作用是標記日志是否記錄入文件之中,可以指定標記的日志記錄到文件中;也可以指定標記的日志拒絕記錄到文件中,其它未標記的記錄入文件;
一、定義MarkerFilter初始化實例對象
/**
* 全局標記過濾器,接受指定標記的日志記錄到文件中
*
* @param context 上下文
* @param marker marker標識
* @return 標記過濾器,將會接受被標記的日志記錄到文件中
*/
public MarkerFilter getAcceptMarkerFilter(Context context, String marker) {
MarkerFilter filter = new MarkerFilter();
//過濾器名稱
filter.setName(StrUtils.join("AcceptMarkerFilter-", marker));
//上下文
filter.setContext(context);
//日志過濾級別
filter.setMarker(marker);
//設(shè)置符合條件的日志接受
filter.setOnMatch(FilterReply.ACCEPT.name());
//不符合條件的日志拒絕
filter.setOnMismatch(FilterReply.DENY.name());
//添加內(nèi)部狀態(tài)信息
filter.addError("Build AcceptMarkerFilter Success");
//標記為啟用狀態(tài)
filter.start();
return filter;
}
/**
* 全局標記過濾器,拒絕標記的日志記錄到文件中
*
* @param context 上下文
* @param marker marker標識
* @return 標記過濾器,將會拒絕被標記的日志記錄到文件中
*/
public MarkerFilter getDenyMarkerFilter(Context context, String marker) {
MarkerFilter filter = new MarkerFilter();
//過濾器名稱
filter.setName(StrUtils.join("DenyMarkerFilter-", marker));
//上下文
filter.setContext(context);
//日志過濾級別
filter.setMarker(marker);
//設(shè)置符合條件的日志接受
filter.setOnMatch(FilterReply.DENY.name());
//不符合條件的日志拒絕
filter.setOnMismatch(FilterReply.ACCEPT.name());
//添加內(nèi)部狀態(tài)信息
filter.addError("Build DenyMarkerFilter Success");
//標記為啟用狀態(tài)
filter.start();
return filter;
}上述定義了一個指定標記的日志會被記錄入文件的MarkerFilter過濾器,一個指定標記的日志不會被記錄日志文件,其它日志文件會被記錄入文件。
二、將MarkerFilter添加到LoggerContext上下文
private static final LoggerContext LOGGER_CONTEXT = (LoggerContext) LoggerFactory.getILoggerFactory(); context.addTurboFilter(LogbackFilter.getSingleton().getAcceptMarkerFilter(context, marker)); context.addTurboFilter(LogbackFilter.getSingleton().getDenyMarkerFilter(context, marker));
上述代碼比較簡單,詳情可以參考源碼;上述會將定義好的兩個全局過濾器添加到LoggerContext中,接下來就可以根據(jù)需要標記日志,控制是否輸出到日志文件。
三、標記日志使用示例
private static final Logger baseLogger = LoggerFactory.getLogger(LogbackController.class);
private static final Marker marker = MarkerFactory.getMarker("instance_marker");
baseLogger.error("--------error");
baseLogger.info("--------info");
baseLogger.debug("--------debug");
baseLogger.warn("--------warn");
baseLogger.trace("--------trace");
baseLogger.error(marker, "--------marker error");
baseLogger.info(marker, "--------marker info");
baseLogger.debug(marker, "--------marker debug");
baseLogger.warn(marker, "--------marker warn");
baseLogger.trace(marker, "--------marker trace");
上述示例如果指定的標記設(shè)置為接受打印到日志文件,則你會在日志文件中、控制臺上看到帶有marker的日志信息;如果標記的日志被設(shè)置為拒絕,則在日志文件、控制臺上看到的就是不帶marker的日志信息;
到此這篇關(guān)于Java中的logback標記日志過濾器MarkerFilter詳解的文章就介紹到這了,更多相關(guān)logback標記日志過濾器MarkerFilter內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot利用自定義注解實現(xiàn)隱私數(shù)據(jù)脫敏(加密顯示)的解決方案
這兩天在整改等保測出的問題,里面有一個“用戶信息泄露”的風(fēng)險項(就是后臺系統(tǒng)里用戶的一些隱私數(shù)據(jù)直接明文顯示了),其實指的就是要做數(shù)據(jù)脫敏,本文給大家介紹了SpringBoot利用自定義注解實現(xiàn)隱私數(shù)據(jù)脫敏(加密顯示)的解決方案,需要的朋友可以參考下2023-11-11
SpringBoot設(shè)置Session失效時間的解決方案
當過期時間是大于1分鐘的時候是沒有什么問題的,但是如果設(shè)置過期時間小于1分鐘,就會失效,這篇文章主要介紹了SpringBoot設(shè)置Session失效時間的解決方案,需要的朋友可以參考下2024-05-05
Java CRM系統(tǒng)用戶登錄功能實現(xiàn)代碼實例
這篇文章主要介紹了Java CRM系統(tǒng)用戶登錄功能實現(xiàn)代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-04-04
Spring Security OAuth2集成短信驗證碼登錄以及第三方登錄
這篇文章主要介紹了Spring Security OAuth2集成短信驗證碼登錄以及第三方登錄,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-04-04

