中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》
  • 首頁 > 
  • 教程 > 
  • 開發技術 > 
  • Logback如何使用TurboFilter實現日志級別等內容的動態修改操作

Logback如何使用TurboFilter實現日志級別等內容的動態修改操作

發布時間:2021-08-30 13:50:08 來源:億速云 閱讀:176 作者:小新 欄目:開發技術

這篇文章主要介紹Logback如何使用TurboFilter實現日志級別等內容的動態修改操作,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

為什么要通過TurboFilter去動態的修改日志級別

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

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

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

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

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

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>

或者也可以在應用主類中增加:

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

更多關于Logback過濾器的內容可參考官方文檔

logback動態設置某個類的日志級別

假設一下,現在有這么個情況

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

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

于是就有了下面的方案

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

 public void testLog(String key, String level, String level2){
        LoggerContext loggerContext= (LoggerContext) LoggerFactory.getILoggerFactory();
        //設置全局日志級別
        ch.qos.logback.classic.Logger logger=loggerContext.getLogger("root");
        logger.setLevel(Level.toLevel(level));
 
        if (!StringUtils.isBlank(level2)) {
            //設置某個類日志級別-可以實現定向日志級別調整
            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"

表示把全局日志級別設置為ERROR級別,單獨把com.duy.soo.web.controller.TestController類的日志設置為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日志信息。

以上是“Logback如何使用TurboFilter實現日志級別等內容的動態修改操作”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

瑞安市| 高阳县| 六枝特区| 武清区| 泗洪县| 彰武县| 二连浩特市| 蓬莱市| 佛教| 武义县| 鸡泽县| 日喀则市| 旬阳县| 比如县| 遂川县| 烟台市| 鞍山市| 津市市| 澄城县| 二连浩特市| 安宁市| 银川市| 柳河县| 亚东县| 芮城县| 南漳县| 长岛县| 宿州市| 鲁山县| 阿尔山市| 海原县| 江孜县| 双鸭山市| 长岭县| 扎鲁特旗| 新晃| 保靖县| 博客| 威海市| 沙雅县| 吉水县|