亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Logback 使用TurboFilter實現(xiàn)日志級別等內(nèi)容的動態(tài)修改操作

 更新時間:2021年08月30日 10:29:13   作者:程序猿DD  
這篇文章主要介紹了Logback 使用TurboFilter實現(xiàn)日志級別等內(nèi)容的動態(tài)修改操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

Logback TurboFilter實現(xiàn)日志級別等內(nèi)容的動態(tài)修改

可能看到這個標(biāo)題,讀者會問:要修改日志的級別,不是直接修改log.xxx就好了嗎?為何要搞那么復(fù)雜呢?所以,先說一下場景

為什么要通過TurboFilter去動態(tài)的修改日志級別

我們在使用Java開發(fā)各種項目的時候必然的會引入很多框架,這些框架通過堆疊的方式完成所要提供的業(yè)務(wù)服務(wù)(一個服務(wù)請求在進入后會在這些框架中兜一圈,然后返回結(jié)果),當(dāng)一個比較底層的框架在處理過程中拋出了異常之后,這個異常會不斷的向上傳遞。

這個時候,有的框架直接throw,繼續(xù)向上拋,而有的在throw之前還會自己打印一下error日志,這就導(dǎo)致了當(dāng)出現(xiàn)異常的時候,往往會出現(xiàn)一連串類似的錯誤日志記錄。如果對接了錯誤日志告警,就會出現(xiàn)重復(fù)告警的現(xiàn)象。為了解決類似這樣的問題,修改源碼重新編譯最直接,但是不可取。

所以希望可以有更好的手段去控制這些已經(jīng)被編碼固化的日志打印信息。當(dāng)我們使用Logback的時候,TurboFilter就是解決該問題的工具之一。

TurboFIlter不同于之前在[《Logback中如何自定義靈活的日志過濾規(guī)則》]一文中介紹的那些通過ch.qos.logback.core.filter.Filter接口實現(xiàn)的過濾器。ch.qos.logback.core.filter.Filter實現(xiàn)的過濾器是與Appender綁定的,而TurboFIlter是與日志上下文綁定的,它會過濾所有的日志請求,并且TurboFIlter的方法中提供了豐富的可訪問信息用來進行控制和改寫。

比如下面的實現(xiàn),通過繼承ch.qos.logback.classic.turbo.TurboFilter類,并重寫decide方法,將org.springframework.cloud.sleuth.instrument.web.ExceptionLoggingFilter類中原本要打印的ERROR日志DENY掉(過濾掉),同時以WARN級別打印一封相同的內(nèi)容,這樣就實現(xiàn)了對已定義日志的動態(tài)修改。

public class ForceWarnFilter extends TurboFilter {
    @Override
    public FilterReply decide(Marker marker, Logger logger, Level level, String format, Object[] params, Throwable throwable) {
        if (level == Level.ERROR && logger.getName().equals("org.springframework.cloud.sleuth.instrument.web.ExceptionLoggingFilter")) {
            logger.warn(marker, format, params);
            return FilterReply.DENY;
        }
        return FilterReply.NEUTRAL;
    }
}

為了讓上面定義的過濾器生效,需要在logback的配置xml中增加如下配置:

<configuration>
    <turboFilter class="com.didispace.log.filter.ForceWarnFilter" />
    ......
</configuration>

或者也可以在應(yīng)用主類中增加:

LoggerContext lc = (LoggerContext) LoggerFactory.getILoggerFactory();
lc.addTurboFilter(new MyTurboFilter());

更多關(guān)于Logback過濾器的內(nèi)容可參考官方文檔

logback動態(tài)設(shè)置某個類的日志級別

假設(shè)一下,現(xiàn)在有這么個情況

你調(diào)別人的接口出問題了,但是怎么排查都定位不了原因。只能借助更詳細(xì)的日志信息,這個時候,又不想把全局的日志級別調(diào)低,畢竟調(diào)低對并發(fā)量大的應(yīng)用來說,瞬間會涌出很多很多日志信息。

最好的情況就是,只調(diào)整出問題的那個類的日志級別。那怎么辦呢?

于是就有了下面的方案

定向修改某個class的logger日志級別。

 public void testLog(String key, String level, String level2){
        LoggerContext loggerContext= (LoggerContext) LoggerFactory.getILoggerFactory();
        //設(shè)置全局日志級別
        ch.qos.logback.classic.Logger logger=loggerContext.getLogger("root");
        logger.setLevel(Level.toLevel(level));
 
        if (!StringUtils.isBlank(level2)) {
            //設(shè)置某個類日志級別-可以實現(xiàn)定向日志級別調(diào)整
            ch.qos.logback.classic.Logger vLogger = loggerContext.getLogger(key);
            if (vLogger!=null)
                vLogger.setLevel(Level.toLevel(level2));
        }
 
        List<ch.qos.logback.classic.Logger> loggerList = loggerContext.getLoggerList();
        for (ch.qos.logback.classic.Logger logger1 : loggerList){
            log.info(logger1.getName());
        }
    }

比如:

     level = ERROR
     level2 = INFO
     key = "com.duy.soo.web.controller.TestController"

表示把全局日志級別設(shè)置為ERROR級別,單獨把com.duy.soo.web.controller.TestController類的日志設(shè)置為INFO級別。

/**
 * @Author changle
 * @Time 17/6/30.
 * @Desc to do
 */
@Slf4j
@Controller
@RequestMapping(value = "/api/test")
public class TestController {
    @RequestMapping("/testDebug")
    @ResponseBody
    public Response<String> testLog(String key){
        //打印日志級別
        String rtn = "this is a INFO";
        log.info(rtn);
        rtn = "this is a ERROR";
        log.error(rtn);
        rtn = "this is a DEBUG";
        log.debug(rtn);
        Response<String> response = Response.ok(rtn);
        return response;
    }
}

如此一來,除了com.duy.soo.web.controller.TestController類以外的其他類,都只輸出ERROR日志,而TestController類能輸出INFO日志信息。

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

相關(guān)文章

  • 深入了解Spring的事務(wù)傳播機制

    深入了解Spring的事務(wù)傳播機制

    Spring事務(wù)傳播機制是指,包含多個事務(wù)的方法在相互調(diào)用時,事務(wù)是如何在這些方法間傳播的。本文通過示例詳細(xì)介紹了Spring的事務(wù)傳播機制,需要的可以參考一下
    2022-09-09
  • 利用Java實現(xiàn)網(wǎng)站聚合工具

    利用Java實現(xiàn)網(wǎng)站聚合工具

    互聯(lián)網(wǎng)上有數(shù)以萬億計的網(wǎng)站,每個網(wǎng)站大都具有一定的功能。搜索引擎雖然對互聯(lián)網(wǎng)上的部分網(wǎng)站建立了索引,但是其作為一個大而全的搜索系統(tǒng),無法很好的定位到一些特殊的需求。因此本文將介紹一個用java實現(xiàn)的網(wǎng)站數(shù)據(jù)聚合工具,需要的可以參考一下
    2022-01-01
  • SpringBoot_Cache自定義使用SimpleCacheManager方式

    SpringBoot_Cache自定義使用SimpleCacheManager方式

    這篇文章主要介紹了SpringBoot_Cache自定義使用SimpleCacheManager方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • springboot項目集成swagger-bootstrap-ui全過程

    springboot項目集成swagger-bootstrap-ui全過程

    這篇文章主要介紹了springboot項目集成swagger-bootstrap-ui全過程,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • Spring中的@PostConstruct注解使用方法解析

    Spring中的@PostConstruct注解使用方法解析

    這篇文章主要介紹了Spring中的@PostConstruct注解使用方法解析,@PostConstruct注解是用來處理在@Autowired注入屬性后init()方法之前,對一些零散的屬性進行賦值的注解,需要的朋友可以參考下
    2023-11-11
  • Spring Boot如何支持嵌入式Servlet容器

    Spring Boot如何支持嵌入式Servlet容器

    這篇文章主要介紹了Spring Boot如何支持嵌入式Servlet容器,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-10-10
  • 詳解Java利用同步塊synchronized()保證并發(fā)安全

    詳解Java利用同步塊synchronized()保證并發(fā)安全

    這篇文章主要介紹了Java利用同步塊synchronized()保證并發(fā)安全,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • java char數(shù)據(jù)類型原理解析

    java char數(shù)據(jù)類型原理解析

    這篇文章主要介紹了java char數(shù)據(jù)類型原理解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-02-02
  • java環(huán)境中的JDK、JVM、JRE詳細(xì)介紹

    java環(huán)境中的JDK、JVM、JRE詳細(xì)介紹

    這篇文章主要介紹了java環(huán)境中的JDK、JVM、JRE詳細(xì)介紹的相關(guān)資料,對于初學(xué)者還是有必要了解下,細(xì)致說明他們是什么,需要的朋友可以參考下
    2016-11-11
  • java遍歷讀取整個redis數(shù)據(jù)庫實例

    java遍歷讀取整個redis數(shù)據(jù)庫實例

    這篇文章主要介紹了java遍歷讀取整個redis數(shù)據(jù)庫實例,使用支持正則表達(dá)式的key搜索方法jedis.keys(“*”)實現(xiàn),需要的朋友可以參考下
    2014-05-05

最新評論