标签:角色 width nbsp div code strong -o 过程 api
在实际的日志转换过程中,SLF4J其实是充当了一个中介的角色。例如当我们一个项目原来是使用LOG4J进行日志记录,但是我们要换成LogBack进行日志记录。
此时我们需要先将LOG4J转换成SLF4J日志系统,再从SLF4J日志系统转成LogBack日志系统。
从日志框架转向SLF4J
从SLF4J转向具体的日志框架
我们以图中的左上部分为例来说明下。目前的应用程序中已经使用了如下混杂方式的API来进行日志的编程:
现在想统一将日志的输出交给 logback。解决方法是:
在使用Slf4j桥接时要注意避免形成死循环,在项目依赖的jar包中不要存在以下情况:
多个日志jar包形成死循环的条件 | 产生原因 |
log4j-over-slf4j.jar和slf4j-log4j12.jar同时存在 |
由于slf4j-log4j12.jar的存在会将所有日志调用委托给log4j。但由于同时由于log4j-over-slf4j.jar的存在,会将所有对log4j api的调用委托给相应等值的slf4j,所以log4j-over-slf4j.jar和slf4j-log4j12.jar同时存在会形成死循环 |
jul-to-slf4j.jar和slf4j-jdk14.jar同时存在 |
由于slf4j-jdk14.jar的存在会将所有日志调用委托给jdk的log。但由于同时jul-to-slf4j.jar的存在, 会将所有对jul api的调用委托给相应等值的slf4j,所以jul-to-slf4j.jar和slf4j-jdk14.jar同时存在会形成死循环 |
标签:角色 width nbsp div code strong -o 过程 api
原文地址:https://www.cnblogs.com/caoweixiong/p/11285988.html