日志框架的关系:slf4j,slf4j-log4j12,log4j,logback

slf4j  (simple  log facade for java)与 JCL(Jakarta-commons-logging),是日志框架的接口定义层

log4j,log4j2与logback是日志接口实现层。

 

logback比log4j性能更优,直接实现了slf4j。

桥接层:log4j没有直接实现slf4j, 因此需要适配层 slf4j-log4j12 来适配实现 slf4j接口。

    log4j2没有直接实现slf4j,因此需要适配层 log4j-slf4j-impl 来适配实现 slf4j接口。

 

记录一次日志无法输出的问题:感谢博主的文章:

https://www.cnblogs.com/zeng1994/p/df2559e6dc66c99065676e0ee70545eb.html

 

问题原因是 桥接层的绑定问题:

slf4j 找到了多个桥接绑定依赖{slf4j-log4j12, log4j-slf4j-impl },项目采用了Log4j2,那么此时由于JVM随机绑定到slf4j-log4j12,会导致日志无法输出。解决方案,即 排除slf4j-log4j12即可。

 

posted @ 2022-01-07 16:10  魔杰Lee  阅读(1574)  评论(0编辑  收藏  举报