问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

Slf4j + Logback 怎么过滤掉第三方包中的日志显示

发布网友 发布时间:2022-05-01 21:55

我来回答

1个回答

热心网友 时间:2022-04-14 13:51

其实这跟 Slf4J 通用日志框架没什么关系,单单是 Logback 的事,把 Slf4J 扯进来只因它们是对黄金组合。
我们在 log4j 中想要不显示第三方包的非常冗余的日志输出时,只要在 log4j.properties 中写上:

1

log4j.logger.org.hibernate=ERROR

这样在 hibernate 里的日志级别在 ERROR 以下的 TRACE、DEBUG、WARN 和 INFO 将不被输出,控制台会比较的干净。
Logback 的配置文件是 logback.xml,曾经在里面给 <appender> 加的 <pattern> 是:

1

<pattern>%-4relative [%thread] %-5level %logger{35} - %msg%n</pattern>

logger 名显示 35 字符,类名优先显示全,类全限名超过总长度则取前面若干包名的首字母连接起来,于是产生了像下面那样的日志输出:
7937 [main] DEBUG o.s.b.f.s.DefaultListableBeanFactory - Returning cached instance of singleton
7781 [main] DEBUG o.h.loader.entity.EntityLoader - Static select for entity
这在 Log4J 中是未曾见过的。当时还以为日志名就是 o.s.b.f 这样的东西,于是在 logback.xml 中用

1
2

<logger name="o.s.b" level="WARN"/>
<logger name="o.h" level="WARN"/>

这样的代码来进行封锁,根本就无济于事,大量的 spring、hibernate 的 DEBUG、INFO 等日志照样输出。这时惦记起 Logback 的 filter 功能来了,配置上:

01
02
03
04
05
06
07
08
09
10
11

<filter>
<evaluator> <!-- defaults to type ch.qos.logback.classic.boolex.JaninoEventEvaluator -->
<expression><![CDATA[
event.getThreadName().contains("Catalina")
|| event.getLoggerName().contains("o.s.b.f")
|| event.getLoggerName().contains("o.h.")
]]></expression>
</evaluator>
<OnMismatch>NEUTRAL</OnMismatch>
<OnMatch>DENY</OnMatch>
</filter>

也是没有效果的。想来 Logback 与 Log4J 相比不会这么差劲的,再怎么也是出自一人之手,想来思路应是一致的,还是该回到 <logger> 的配置上来。
还是 Google 威武,找到答案了:logback per-logger configuration is not working。原来像 "o.s.b.f" 和 "o.h." 这样的东西只是神马浮云,假象而已,它们实际所代表的 logger 名并未变,分别是:
org.springframework.beans.factory.support.DefaultListableBeanFactory
org.hibernate.loader.entity.EntityLoader
所以呢,在 logback.xml 中像 Log4J 一样写上

1
2

<logger name="org.hibernate" level="WARN"/>
<logger name="org.springframework" level="WARN"/>

就把 Spring 和 Hibernate 的日志输出稍加过滤了,都是 %logger{35} 中的那个 {35} 惹的祸,不过也靠它多了解了一点东西。如果只写成 %logger 话那时候当然可以很快的解决问题的。
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
在线条形码生成 ie地址栏是什么 ie浏览器的官网地址是什么? 团餐定制电话 抖音电商与广东商务厅启动“富域计划” 简单的晚餐晒美食文案句子 简单的晚餐晒美食说说短句 鸭肉炒什么好吃家常做法 为什么越背越记不住 绯牡丹锦多久浇水 绯牡丹养护要点 b超检查中低回声是什么意思 大金挂壁式空调1·5匹外机尺寸多少 logback怎么输出tomcat日志 宫壁低回声什么意思 护师资格证,如果单位不是当年聘用,会不会失效以后要重考?几年有效期呢?是护师,不是*!!!! 兔死狐悲,解是什么生肖? logback.xml配置 护士怎样升为护师 logback运行时异常怎么记录 兔死狐悲,是什么生肖呢? logback logger appender encoder pattern是什么意思 logback怎么根据logger输出不同文件 初级护师的报名需要什么条件? logback需要配置哪些东西 logback是怎么格式化 本科护理学毕业后是可以直接由医院聘任为初级护师吗? logback怎么设置日志格式 兔死狐悲指十二生肖什么动物? 微信2怎么开 初级护师取得聘任时间写什么时候? 谜语 兔死狐悲假慈悲 猜一动物 大金1.5匹空调底角距离是多少 logback怎样通过http访问log 护师报名在网上已报好,但我现在没有工作单位怎么办 低回声团块是什么意思 大金空调FTXF135KC-R 型号和FTXF135KC-W有什么不同 java怎么用logback做日志记录以html的形式展示 如何在logback日志配置文件中配置相对路径 大金空调具体尺寸 大金空调帕蒂能外机尺寸 足部皮下低回声区是啥意思 java启动如何去掉logback自身调试信息 甲状腺结节样低回声是什么意思 大金外机140金制重量及尺寸 logback可以定义两个root日志吗 肝内见23*20*16mm低回声是什么意思? spring boot logback日志 怎么彩色输出 宫腔内低回声区是什么意思? 照阴道B超内低回声是什么意思? 子宫前壁低回声是什么意思,23mm*20mm?