您好,登錄后才能下訂單哦!
這篇文章主要介紹Logback如何使用TurboFilter實現(xiàn)日志級別等內(nèi)容的動態(tài)修改操作,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
我們在使用Java開發(fā)各種項目的時候必然的會引入很多框架,這些框架通過堆疊的方式完成所要提供的業(yè)務(wù)服務(wù)(一個服務(wù)請求在進入后會在這些框架中兜一圈,然后返回結(jié)果),當一個比較底層的框架在處理過程中拋出了異常之后,這個異常會不斷的向上傳遞。
這個時候,有的框架直接throw,繼續(xù)向上拋,而有的在throw之前還會自己打印一下error日志,這就導致了當出現(xiàn)異常的時候,往往會出現(xiàn)一連串類似的錯誤日志記錄。如果對接了錯誤日志告警,就會出現(xiàn)重復告警的現(xiàn)象。為了解決類似這樣的問題,修改源碼重新編譯最直接,但是不可取。
所以希望可以有更好的手段去控制這些已經(jī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)容可參考官方文檔
你調(diào)別人的接口出問題了,但是怎么排查都定位不了原因。只能借助更詳細的日志信息,這個時候,又不想把全局的日志級別調(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日志信息。
以上是“Logback如何使用TurboFilter實現(xiàn)日志級別等內(nèi)容的動態(tài)修改操作”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。