http://www.slf4j.org/全称:Simple Logging Facade for Java简单日志门 面(Facade)SLF4J是为各种loging APIs提供一个简单统一的接口,从而使得最终用户能够在部署的时候配置自己希望的 loging APIs实现。Logging API实现既可以选择直接实现SLF4J接口的loging APIs如: logback、 SimpleLogger。也可以通过开发相应的适配器来使用已有的API实现如Log4jLoggerAdapter、 JDK14LoggerAdapter。SLF4J 不依赖任何特殊的class loader机制,实际上,SLF4J 和已有日志实现的绑定是在编译 时静态执行的,具体绑定工作是通过一个jar包实现的,使用时只要把相应的jar包(只有一个)放到类路径上即可。在 SLF4J发行版本中包含了几个 jar包,如slf4j-nop.jar, slf4j-simple.jar, slf4j-log4j12.jar, slf4j- log4j13.jar, slf4j-jdk14.jar and slf4j- jcl.jar,Each of these jar files is hardwired at compile- time to use just one implementation, that is NOP, Simple, log4j version 1.2, log4j version 1.3, JDK 1.4 logging, and repectively JCL 等.SLF4J支持多个日志系统,比如 NOP, Simple, log4j version 1.2, log4j version 1.3, JDK 1.4 logging, JCL and logback。使用slf4j尽管很方便,但是让很多人搞不明白slf4j那么多包怎么用。
其 实 slf4j原理很简单,他只提供一个核心slf4j api(就是slf4j-api.jar包),这个包只有日志的接口,并没有实现,所以如果要使用就 得再给它提供一个实现了些接口的日志包,比 如:log4j,common logging,jdk log日志实现包等,但是这些日志实现又不能通过接 口直接调用,实现上他们根本就和slf4j-api不一致,因此slf4j又增加了一层来转换各日志实 现包的使用,当然slf4j-simple除外。 其结构如下:
slf4j-api(接口层)
|
各日志实现包的连接层( slf4j-jdk14, slf4j-log4j)
|
各日志实现包
下面这个图更能说明其原理:
在这里还需要注意的是,连接层的jar包和实现的jar的版本要一致。
附jar说明:
slf4j-api-1.6.1.jar --> slf4j核心接口包
slf4j-simple-1.6.1.jar --> slf4j Simple Logger日志实现包
slf4j-nop-1.6.1.jar -->
slf4j-migrator-1.6.1.jar -->
slf4j-log4j12-1.6.1.jar --> slf4j调用log4j的实现包
slf4j-jdk14-1.6.1.jar --> slf4j调用jdk java.util.logging的实现包
slf4j-jcl-1.6.1.jar --> Jakarta Commons Logging
slf4j-ext-1.6.1.jar -->
log4j-over-slf4j-1.6.1.jar -->
jul-to-slf4j-1.6.1.jar -->
jcl-over-slf4j-1.6.1.jar -->
slf4j+log4j组合使用模式:
1. slf4j-api-1.5.11.jar
2. slf4j-log4j12-1.5.11.jar
3. log4j-1.2.15.jar
4. log4j.properties(也可以是 log4j.xml,本例中用 log4j.propertes)
JCL+Log4J组合使用模式:
1. commons-logging-1.1.jar
2. log4j-1.2.15.jar
3. log4j.properties
把这种 SLF4J+Log4J 的使用模式与曾为霸主地位的 JCL+Log4J 的用法进行一下对比(请忽略掉包文件中的版本号):
SLF4J+Log4j 组合对比JCL+Log4J 组合slf4j-api-1.5.11.jar相当,定义高层 APIcommons-logging-1.1.jarslf4j-log4j12-1.5.11.jar相当,左边是用绑定包,右边
是用配置文件来指定日志实现commons-logging.properties,内容为:
org.apache.commons.logging.LogFactory=
org.apache.commons.logging.impl.LogFactoryImpl
或者
org.apache.commons.logging.Log=
org.apache.commons.logging.impl.Log4JLoggerlog4j-1.2.15.jar一样log4j-1.2.15.jarlog4j.properties一样,原来怎么配置现在也是log4j.properties程序代码中:
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
Logger logger = LoggerFactory.getLogger(TestSlf4j.class);
logger.info("Hello {}","SLF4J");左边侵入的是 SLF4J API,右边是被 JCL 的 API 污染了
SLF4J 支持参数化,而 JCL 不能程序代码中:
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
Log log = LogFactory.getLog(TestJCL.class);
log.info("Hello JCL");
从上面的对比来看,SLF4j+Log4j 与 JCL+Log4J 的使用方式差不多,主要差异就在 SLF4J 用 jar 来告知用哪种日志实现,而 JCL 是通过配置文件来获得该选择哪个日志实现。
为 什 么会兴起 SLF4J,看看我们原来哪一个框架中,大的如 SSH 三雄(Spring、Struts、Hibernate),还有 WAS 应用服务 器,小的就不计其数以前用的通用日志框架都清一色的 Jakarta Commons Logging(JCL),日志实现会选用 Log4j,为何现 在 Hibernate、Tapesty、DbUnit、Jetty V6 等纷纷变节,都采用了 SLF4J 了呢?SLF4J 与 JCL 相比,定 然是有其可表之处。而其中 SLF4J 受类加载器的影响较小,不易产生内存溢出的问题,性能得到了改善,更主要是顺应了潮流的发展--可方便部署 到 OSGI 环境中。
如何使用slf4j
下边一段程序是经典的使用slf4j的方法.
import org.slf4j.LoggerFactory;
public class Wombat {
final Logger logger = LoggerFactory.getLogger(Wombat. class );
Integer t;
Integer oldT;
public void setTemperature(Integer temperature) {
oldT = t;
t = temperature;
logger.error( " Temperature set to {}. Old temperature was {}. " , t, oldT);
if (temperature.intValue() > 50 ) {
logger.info( " Temperature has risen above 50 degrees. " );
}
}
public static void main(String[] args) {
Wombat wombat = new Wombat();
wombat.setTemperature( 1 );
wombat.setTemperature( 55 );
}
}
下边介绍一下运行上边程序的过程。
1,编译上边的程序,需要classpath中加入slf4j-api-1.4.1.jar文件
2,运行时,需要classpath中加上slf4j-simple-1.4.1.jar
运行得到结果:
----------------------------
0 [main] ERROR Wombat - Temperature set to 1. Old temperature was null.
0 [main] ERROR Wombat - Temperature set to 55. Old temperature was 1.
0 [main] INFO Wombat - Temperature has risen above 50 degrees.
这个是simple log风格,
3,切换:如果想切换到jdk14的log的风格,只需要把slf4j-simple-1.4.1.jar
从classpath中移除,同时classpath中加入slj4j-jdk14-1.4.1.jar
这时的运行结果:
---------------------------------------------------
2007-7-9 10:40:15 Wombat setTemperature
严重: Temperature set to 1. Old temperature was null.
2007-7-9 10:40:16 Wombat setTemperature
严重: Temperature set to 55. Old temperature was 1.
2007-7-9 10:40:16 Wombat setTemperature
信息: Temperature has risen above 50 degrees.
已经变成jdk14的log风格了。
4,再次切换到log4j
同样移除slj4j-jdk14-1.4.1.jar,加入slf4j-log4j12-1.4.1.jar,同时加入log4j-1.2.x.jar
加入log4j.properties。得到显示结果:
---------------------------------------
10:42:27,328 ERROR Wombat: Temperature set to 1. Old temperature was null.
10:42:27,328 ERROR Wombat: Temperature set to 55. Old temperature was 1.
10:42:27,328 INFO Wombat: Temperature has risen above 50 degrees.
在不同的风格中切换只需要在部署期切换类库就可以了,和开发时无关。
相关推荐
SLF4J(Simple Logging Facade for Java)是一个用于Java编程语言的日志门面框架,它提供了一个简单的抽象层,用以使用各种日志框架,例如java.util.logging、logback和log4j。门面模式的好处在于,开发者可以在不同...
Log4j2 结合 Slf4j 配置使用 Log4j2 是一个功能强大且广泛使用的日志记录工具,它提供了灵活的日志记录机制和高性能的日志记录能力。Slf4j 则是一个简单的日志记录门面,提供了统一的日志记录接口。今天,我们将...
SLF4J(Simple Logging Facade for Java)是Java中的一种日志门面(Logging Facade),它为各种日志框架提供了一个简单的统一接口,如Log4j、Java Util Logging、Logback等。这个jar包是SLF4J的核心组件,用于在应用...
具体来说,这个版本(1.7.12)的绑定包实现了SLF4J的API,并将其桥接到log4j的实现上,使得开发者可以通过SLF4J的API来使用log4j的功能。"slf4j-api-1.7.12.jar"则是SLF4J的核心API库,包含了所有SLF4J的日志记录...
Java Slf4j,全称为Simple Logging Facade for Java,是一个为各种日志框架提供一个简单统一的接口,使得最终用户能够在部署时配置他们希望的日志框架。Slf4j允许开发者在部署应用时插入所需的日志实现,无需修改...
SLF4J(Simple Logging Facade for Java)是Java中的一种日志抽象层,它为各种日志框架,如Log4j、Logback等提供一个简单的接口,使得开发者能够在不改变代码的情况下更换日志实现。这个接口使得应用程序的代码与...
SLF4J(Simple Logging Facade for Java)是Java中一个重要的日志接口框架,它为各种日志实现提供了一个抽象层,使得开发者能够在运行时动态地选择具体使用的日志实现,例如Log4j、Java Util Logging (JUL)、Logback...
3. **API**: SLF4J提供了一组简单的API,如`logger.info()`, `logger.debug()`, `logger.error()`等,供开发者使用。 4. **日志绑定**: SLF4J允许在运行时绑定不同的日志实现。例如,如果项目中包含logback-classic....
3. **配置简单**: 如果项目中包含了NOP绑定,SLF4J将自动选择这个实现,无需额外配置。 4. **兼容性**: 使用NOP绑定不会影响SLF4J API的使用,因为API与实现之间是解耦的。 **使用SLF4J的好处** 1. **灵活性**: ...
SLF4J(Simple Logging Facade for Java)是Java中的一种日志门面,它提供了一个简单的接口,允许开发者在不修改代码的情况下切换不同的日志实现。SLF4J的出现是为了统一各种日志框架,如Log4j、java.util.logging、...
SLF4J的主要目标是提供一个简单易用的日志API,允许开发者在部署时插入所需的日志框架。SLF4J API仅包含接口和辅助类,实际的日志实现需要通过绑定特定的日志库来完成。例如,如果项目中引入了`logback-classic`,...
SLF4J(Simple Logging Facade for Java)是Java日志记录的一个接口层,它为各种日志框架,如Log4j、Logback等提供一个简单的抽象层,使得最终用户能够在部署时插入所需的日志实现。`slf4j-api-1.7.7.jar`是SLF4J ...
1. **SLF4J API**:SLF4J提供了简单的API接口,包括`org.slf4j.Logger`,`org.slf4j.LoggerFactory`和`org.slf4j.Marker`等。`LoggerFactory`用于获取`Logger`实例,`Logger`则提供了各种级别的日志记录方法,如`...
SLF4J(Simple Logging Facade for Java)是Java中的一种日志抽象层,它提供了一个简单的API,允许开发者在应用程序中使用各种日志框架,如Log4j、Logback等,而无需直接依赖特定的日志实现。SLF4J 1.7是其的一个...
如果你的应用程序中已经使用了Log4j,这个绑定库会帮助你将SLF4J的日志调用转换为Log4j的调用。 3. **slf4j-simple.jar**:这是另一个绑定库,它提供了一个简单的日志实现,适合小型应用或测试环境。它将日志信息...
使用Slf4j集成Log4j2构建项目日志系统的完美解决方案 Slf4j是简单的日志外观(Facade)模式,它提供了统一的日志接口,使得用户可以选择不同的日志实现。Slf4j的出现使得日志系统的开发变得更加灵活和便捷。Log4j2...
- **API层**:SLF4J提供了简单的API,供开发者在应用程序中使用,如`Logger logger = LoggerFactory.getLogger(MyClass.class);`,`logger.info("Hello, World!");`。 - **绑定层**:SLF4J API本身不实现日志记录,...
SLF4J(Simple Logging Facade for Java)是Java中的一种日志抽象层,它为各种日志框架,如Log4j、Logback等提供一个简单的接口,使得开发者能够在不改变代码的情况下更换日志实现。在非Web工程中,SLF4J同样扮演着...
SLF4J的主要目标是提供一个简单易用的日志接口,它不关心具体的日志实现,而是允许开发者在部署时通过绑定特定的日志实现库(如Logback、Log4j等)来满足日志记录需求。这样做有几个显著的优点: 1. **灵活性**:...
`slf4j-api-1.7.30.jar`即SLF4J的API包,提供了简单的日志记录接口,开发者可以使用这些接口而不需关心具体的日志实现。通过这个门面,开发者可以在不修改代码的情况下更换底层的日志框架,如从Log4j切换到Logback。...