近段时间在整理以前开发的项目时,从中发现了slf4j;以前从来没用过,在其他地方看到log4j居多,在网上找了下资料,发现还是蛮好用的。slf4j不是具体的日志解决方案,它只服务于各种各样的日志系统。按照官方的说法,slf4j是一个用于日志系统的简单Facade,允许最终用户在部署其应用时使用其所希望的日志系统。而在使用slf4j的时候,不需要在代码中或配置文件中指定你打算使用那个具体的日志系统,slf4j提供了统一的记录日志的接口,只要按照其提供的方法记录即可,最终日志的格式、记录级别、输出方式等通过具体日志系统的配置来实现,因此可以在应用中灵活切换日志系统。
使用方式
在系统开发中,统一按照slf4j的API进行开发,在部署时,选择不同的日志系统包,即可自动转换到不同的日志系统上。比如:选择JDK自带的日志系统,则只需要将slf4j-api-1.6.1.jar和slf4j-jdk14-1.6.1.jar放置到classpath中即可,如果中途无法忍受JDK自带的日志系统了,想换成log4j的日志系统,仅需要用slf4j-log4j12-1.6.1.jar替换slf4j- jdk14-1.6.1.jar即可(需要log4j的jar及配置文件log4j.properties文件),也可以使用slg4j提供的 simple log,slf4j-simple-1.6.1.jar替换slf4j-jdk14-1.6.1.jar。
package com.test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class Slf4jTest {
// 统一按照slf4j的API进行开
Logger logger = LoggerFactory.getLogger(Slf4jTest.class);
public void testLog(){
logger.info("this is a test log");
}
public static void main(String[] args) {
Slf4jTest slf = new Slf4jTest();
slf.testLog();
}
}
(1)使用JDK自带的log输出
在classpath中加入slf4j-api-1.6.1.jar和slf4j-jdk14-1.6.1.jar两个包,然后运行main函数,输出信息如下:
2010-2-23 11:57:28 com.test.Slf4jTest testLog
信息: this is a test log
(2)使用slg4j提供的simple log
slf4j-simple-1.6.1.jar替换slf4j-jdk14-1.6.1.jar,选择使用slf4j提供的simple log,输出信息如下:
[main] INFO com.test.Slf4jTest - this is a test log
(3)log4j日志输出
用slf4j-log4j12-1.6.1.jar替换slf4j-simple-1.6.1.jar(记得classpath也需要增加log4j依赖jar包),同时增加一个log4j.properties文件
我们需要修改下main方法,加载一下log4j.properties,如;
public static void main(String[] args) {
System.setProperty("log4j.configuration", "log4j.properties");
Slf4jTest slf = new Slf4jTest();
slf.testLog();
}
这样就可以以log4j的方式输出了。
(4)格式化日志
SLF4J还提供了格式化日志的功能,如事例中的语句:
logger.info("Today is {}, Temperature set to {}. Old temperature was {}.", objs);
(5)日志系统绑定原理
在应用中,通过LoggerFactory类的静态getLogger()获取logger。通过查看该类的代码可以看出,最终是通过StaticLoggerBinder.SINGLETON.getLoggerFactory()方法获取LoggerFactory然后,在通过该具体的LoggerFactory来获取logger的。类org.slf4j.impl.StaticLoggerBinder并不在 slf4j-api-1.6.1.jar包中,仔细查看每个与具体日志系统对应的jar包,就会发现,相应的jar包都有一个 org.slf4j.impl.StaticLoggerBinder的实现,不同的实现返回与该日志系统对应的LoggerFactory,因此就实现了所谓的静态绑定,达到只要选取不同jar包就能简单灵活配置的目的。
分享到:
相关推荐
压缩包中的"slf4j-nop-1.5.8-sources.jar" 文件包含了SLF4J NOP绑定的源代码,这对于开发者来说非常有价值,因为他们可以查看源码来理解内部工作机制,学习如何实现SLF4J接口,甚至定制自己的日志解决方案。...
总结来说,SLF4J-1.5.0对于学习和使用Apache MINA的开发者来说,是一个不可或缺的工具。它提供了一种灵活的日志记录机制,使得在开发网络应用时能够更好地监控和调试代码。正确理解和使用SLF4J,能够极大地提高开发...
总结来说,SLF4J+Logback是现代Java项目中的首选日志解决方案,因为它们提供了一种灵活、高性能的日志记录机制。然而,理解不同日志框架之间的差异和应用场景,可以帮助开发者根据项目需求做出最佳选择。在实际工作...
【构建Web应用基础】 ...总结,本示例展示了如何整合Maven、Spring MVC、JDBCTEMPLATE和Slf4j,实现MySQL数据库驱动的Web应用。通过这个例子,你可以学习到这些技术的基本使用方法,为后续更复杂的应用开发打下基础。
通过"Logback实例,log4,slf4,logback日志输出demo"的学习,你可以掌握如何配置这些工具,以满足项目需求,如指定日志的存储位置,定制日志格式,以及管理日志文件的生命周期。实践这些示例,将有助于提升你在日志...
总结,Hibernate 3.3.2 + Annotation 3.4.0 + SLF4J 1.5.8的组合在Java应用程序中提供了强大的持久化能力,注解简化了ORM配置,而SLF4J则提供了灵活的日志管理。这种整合方式在过去的项目中广泛使用,虽然现在有更新...
通过学习和掌握其使用,开发者能够提升用户体验,简化内容管理,同时SLF4j的使用则为项目的维护提供了便利。对于初学者,参考提供的使用教程,按照步骤实践,将有助于快速上手并熟练掌握FCKeditor的使用。
总结来说,log4j-2.15.0-rc2是一个安全更新版本,修复了SLF4J的重大漏洞,保障了依赖它的应用的安全性。同时,提供的源码使开发者有机会深入学习和定制这个强大的日志框架。对于使用Java开发的项目,尤其是那些依赖...
SLF4J提供了一组API,使得在代码中插入日志调用变得简单,而具体的日志输出则可以通过绑定不同的日志实现库(如log4j、logback)来控制。这对于项目的可移植性和日志管理的灵活性至关重要。 此外,还有Hibernate的...
标题“log4j学习”暗示了我们即将探讨的是关于Log4j,一个广泛使用的Java日志框架。它主要用于记录应用程序运行过程中的各种事件和异常信息,帮助开发者追踪和诊断问题。描述中提到的“博文链接”指向了一个ITeye上...
与SLF4J(Simple Logging Facade for Java)结合使用,可以实现日志框架的透明切换,增加项目的灵活性。 总结,Log4j作为一个成熟的日志框架,其强大的功能和广泛的社区支持使其在Java开发领域有着不可替代的地位。...
- 可选:`log4j-slf4j-impl.jar` 和 `slf4j-api.jar`,用于与SLF4J(Simple Logging Facade for Java)接口集成。 **三、配置Log4j** Log4j的配置通常通过一个XML或.properties文件进行。以下是一个基本的XML配置...
日志技术是软件开发中不可或缺的一部分,主要用于记录系统运行过程中的事件、错误、警告和调试信息,便于后期问题...通过对JUL、Log4j、Logback和SLF4J等框架的学习,开发者可以根据项目需求选择最适合的日志解决方案。
目前,市场上流行的日志解决方案主要有Log4j、Log4j+JCL以及Log4j+SLF4J等。本文将详细介绍这些日志框架的配置与使用方法。 #### 1.1 下载所需组件 为了进行日志框架的学习与实践,首先需要准备以下组件: 1. **...
2. **slf4j-api.jar和slf4j-log4j12-1.5.2.jar**: Simple Logging Facade for Java (SLF4J) 提供了一层抽象,允许开发者在运行时选择合适的日志实现,slf4j-log4j12是SLF4J和Log4j之间的桥接库。 3. **slf4j-jdk14....
- 日志API:学习如何在代码中使用SLF4J的API进行日志记录,如`org.slf4j.Logger`和`org.slf4j.LoggerFactory`。 - 运行时绑定:理解SLF4J的运行时绑定机制,以及如何在不修改代码的情况下切换日志实现。 总结来说,...
3. SLF4J(Simple Logging Facade for Java):作为一个日志抽象层,允许用户在部署时插入任何日志框架,包括Log4j。 总结来说,Log4j是Java开发中的必备工具,理解和熟练使用Log4j能够极大地提升开发效率和软件...
总结来说,Java中的字符串和文件压缩主要依赖`java.util.zip`包,SLF4J则为日志记录提供便利。通过学习和实践这些技术,开发者可以更好地应对数据处理中的压缩需求,提高程序效率和资源利用率。在实际项目中,还需要...
在Java世界里,除了log4j,还有**Logback**和**SLF4J**。Logback是log4j的后继者,由log4j的创始人Ceki Gülcü开发。它旨在提高性能,提供更高效的日志处理。SLF4J(Simple Logging Facade for Java)则是一个接口...