一、Java日志概述java领域存在多种日志框架,目前常用的日志框架包括Log4j 1,Log4j 2,Commons Logging,Slf4j,Logback,Jul。Commons Logging和Slf4j是日志门面(门面模式是软件工程中常用的一种软件设计模式,也被称为正面模式、外观模式。它为子系统中的一组接口提供一个统一的高层接口,使得子系统更容易使用)。Log4j和Logback则是具体的日志实现方案。可以简单的理解为接口与接口的实现,调用者只需要关注接口而无需关注具体的实现,做到解耦。Commons Logging Apache基金会所属的项目,是一套Java日志接口,之前叫Jakarta Commons Logging,后更名为Commons Logging。Slf4j 类似于Commons Logging,是一套简易Java日志门面,本身并无日志的实现。(Simple Logging Facade for Java,缩写Slf4j)。Logback 一套日志组件的实现(Slf4j阵营)。Logback必须配合Slf4j使用。由于Logback和Slf4j是同一个作者,其兼容性不言而喻。比较常用的组合使用方式是Slf4j与Logback组合使用,Commons Logging与Log4j组合使用。Log4j Apache Log4j是一个基于Java的日志记录工具。它是由Ceki Gülcü首创的,现在则是Apache软件基金会的一个项目。 Log4j是几种Java日志框架之一。Log4j 2 Apache Log4j 2是apache开发的一款Log4j的升级产品。Log4j 2与Log4j 1发生了很大的变化,Log4j 2不兼容Log4j 1。Jul (Java Util Logging),自Java1.4以来的官方日志实现。二、Commons Logging与Slf4j实现机制对比Commons Logging是通过动态查找机制,在程序运行时,使用自己的ClassLoader寻找和载入本地具体的实现。详细策略可以查看commons-logging-*.jar包中的org.apache.commons.logging.impl.LogFactoryImpl.java文件。由于Osgi不同的插件使用独立的ClassLoader,Osgi的这种机制保证了插件互相独立, 其机制限制了Commons Logging在Osgi中的正常使用。Slf4j在编译期间,静态绑定本地的Log库,因此可以在Osgi中正常使用。它是通过查找类路径下org.slf4j.impl.StaticLoggerBinder,然后在StaticLoggerBinder中进行绑定。如果是在一个新的项目中建议使用Slf4j与Logback组合,这样有如下的几个优点:Slf4j实现机制决定Slf4j限制较少,使用范围更广。由于Slf4j在编译期间,静态绑定本地的LOG库使得通用性要比Commons Logging要好。Logback拥有更好的性能。Commons Logging开销更高三、Slf4j与其他日志组件调用关系jar包名说明slf4j-log4j12-1.7.13.jarLog4j1.2版本的桥接器,你需要将Log4j.jar加入Classpath。slf4j-jdk14-1.7.13.jarjava.util.logging的桥接器,Jdk原生日志框架。slf4j-nop-1.7.13.jarNOP桥接器,默默丢弃一切日志。slf4j-simple-1.7.13.jar一个简单实现的桥接器,该实现输出所有事件到System.err. 只有Info以及高于该级别的消息被打印,在小型应用中它也许是有用的。slf4j-jcl-1.7.13.jarJakarta Commons Logging 的桥接器. 这个桥接器将Slf4j所有日志委派给Jcl。logback-classic-1.0.13.jar(requires logback-core-1.0.13.jar)Slf4j的原生实现,Logback直接实现了Slf4j的接口,因此使用Slf4j与Logback的结合使用也意味更小的内存与计算开销。四、使用Slf4j时如何桥接遗留的api当我们在同一项目中使用不同的组件时应该如果解决不同组件依赖的日志组件不一致的情况呢?现在我们需要统一日志方案,统一使用Slf4j,把他们的日志输出重定向到Slf4j,然后Slf4j又会根据绑定器把日志交给具体的日志实现工具。Slf4j带有几个桥接模块,可以重定向Log4j,JCL和java.util.logging中的Api到Slf4j。jar包名作用log4j-over-slf4j-version.jar将Log4j重定向到Slf4jjcl-over-slf4j-version.jar将Commons Logging里的Simple Logger重定向到slf4jjul-to-slf4j-version.jar将Java Util Logging重定向到Slf4j在使用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同时存在会形成死循环参考https://www.cnblogs.com/chenh…