一、常用日志工具包
1、slf4j
slf4j是统一日志调用接口,底层可以使用log4j、logback等具体日志实现类。兼容slf4j的日志工具都需实现org.slf4j.impl.StaticLoggerBinder类,打印日志时,slf4j会查找StaticLoggerBinder的存在,并返回具体日志操作对象。也因此slf4j底层只能存在一个包含StaticLoggerBinder类的日志工具。目前兼容的工具包有:
logback-classic(默认的logback实现)
slf4j-jcl.jar(apache commons logging):使用commons logging实现slf4j定义的接口
slf4j-log4j12.jar(log4j 1.2.4) :使用log4j实现slf4j定义的接口
slf4j-jdk14(java.util.logging) :使用java自带日志库实现slf4j定义的接口
2、common-log
与slf4j一样提供统一调用接口,但获取具体日志实现类方式不同。common-log通过classloader自动加载classpath路径下的日志工具,如果有log4j工具包则使用,如果没有则使用java自动日志工具。由于不能兼容使用OSGI标准的系统,近来逐步被slf4j所替代。
3、log4j与logback
log4j与logback都是具体的日志实现类,由统一个团队开发,由于log4j在效率上存在质疑,该团队根据slf4j接口的开发了logback,作为slf4j的统一默认实现。并且logback的效率要高于log4j,今年来使用比较多
4、桥接器
桥接器是在不改变原有代码的基础上,底层可以使用logback输出的一种解决方案。
如 在工程上常常引用第三方库,里面会用到不同日志库,因为系统只能选定一个,当集成在一个系统后就会存在问题,这时可以使用桥接器。
jcl-over-slf4j.jar/jcl104-over-slf4j:apache commons logging 1.1.1/1.0.4,直接替换即可。
log4j-over-slf4j.jar:log4j,直接替换即可。
二、使用方式
1、logback+slf4j
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.6.1</version>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.0.13</version>
</dependency>
2、log4j
+slf4j
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.6.1</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.7.2</version>
</dependency>
3、原先使用log4j,
现改成logback+slf4j
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.6.1</version>
</dependency>
<!--直接替换掉原有的log4j包-->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>log4j-over-slf4j</artifactId>
<version>1.7.7</version>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.0.13</version>
</dependency>