1.SLF4J(Simple logging Facade for Java)html
意思为简单日志门面,它是把不一样的日志系统的实现进行了具体的抽象化,只提供了统一的日志使用接口,使用时只须要按照其提供的接口方法进行调用便可,因为它只是一个接口,并非一个具体的能够直接单独使用的日志框架,因此最终日志的格式、记录级别、输出方式等都要经过接口绑定的具体的日志系统来实现,这些具体的日志系统就有log4j,logback,java.util.logging等,它们才实现了具体的日志系统的功能。java
如何使用SLF4J?api
既然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包状况为:iphone
SLF4J和logback结合使用时须要提供的jar:slf4j-api.jar,logback-classic.jar,logback-core.jar工具
SLF4J和log4j结合使用时须要提供的jar:slf4j-api.jar,slf4j-log412.jar,log4j.jar性能
SLF4J和JDK中java.util.logging结合使用时须要提供的jar:slf4j-api.jar,slf4j-jdk14.jar.net
SLF4J和simple(SLF4J自己提供的一个接口的简单实现)结合使用时须要提供的jar:slf4j-api.jar,slf4j-simple.jardebug
固然还有其余的日志实现包,以上是常常会使用到的一些。
注意,以上slf4j和各日志实现包结合使用时最好只使用一种结合,否则的话会提示重复绑定日志,而且会致使日志没法输出。
slf4j-api.jar:对外提供统一的日志调用接口,该接口具体提供的调用方式和方法举例说明:
public class Test {
private static final Logger logger = LoggerFactory.getLogger(Tester.class); //经过LoggerFactory获取Logger实例
public static void main(String[] args) {
//接口里的统一的调用方法,各具体的日志系统都有实现这些方法
logger.info("testlog: {}", "test");
logger.debug("testlog: {}", "test");
logger.error("testlog: {}", "test");
logger.trace("testlog: {}", "test");
logger.warn("testlog: {}", "test");
}
}
若是系统中以前已经使用了log4j作日志输出,想使用slf4j做为统一的日志输出,该怎么办呢?
若是以前系统中是单独使用log4j作为日志输出的,这时再想使用slf4j作为日志输出时,若是系统中日志比较多,此时更改日志输出方法确定是不太现实的,这个时候就可使用log4j-over-slf4j.jar将使用log4j日志框架输出的日志路由到slf4j上来统一采用slf4j来输出日志。
为何要使用SLF4J?
2.log4j(log for java)
Log4j是Apache的一个开源项目,经过使用Log4j,咱们能够控制日志信息输送的目的地是控制台、文件、GUI组件,甚至是套接口服务器、NT的事件记录器、UNIX Syslog守护进程等;咱们也能够控制每一条日志的输出格式;经过定义每一条日志信息的级别,咱们可以更加细致地控制日志的生成过程。最使人感兴趣的就是,这些能够经过一个配置文件来灵活地进行配置,而不须要修改应用的代码。
如何使用?
logback一样是由log4j的做者设计完成的,拥有更好的特性,用来取代log4j的一个日志框架,是slf4j的原生实现(即直接实现了slf4j的接口,而log4j并无直接实现,因此就须要一个适配器slf4j-log4j12.jar),logback一共有如下几个模块:
一样,单独使用它时,须要引入以上jar,而后进行配置文件的配置,最后就是在相关类中进行使用,使用时加入如下语句:
private final static Logger logger = LoggerFactory.getLogger(Test.class);
logger.info("打印日志");
对于logback的使用,详细使用方法及配置推荐阅读如下文章:
https://www.cnblogs.com/warking/p/5710303.html
4.总结以下:
一、slf4j是java的一个日志门面,实现了日志框架一些通用的api,log4j和logback是具体的日志框架。
二、他们能够单独的使用,也能够绑定slf4j一块儿使用。
单独使用,分别调用框架本身的方法来输出日志信息。绑定slf4j一块儿使用。调用slf4j的api来输入日志信息,具体使用与底层日志框架无关(须要底层框架的配置文件)。显然不推荐单独使用日志框架。假设项目中已经使用了log4j,而咱们此时加载了一个类库,而这个类库依赖另外一个日志框架。这个时候咱们就须要维护两个日志框架,这是一个很是麻烦的事情。而使用了slf4j就不一样了,因为应用调用的抽象层的api,与底层日志框架是无关的,所以能够任意更换日志框架。
这篇文章主要是来帮你们理清 slf4j,log4j,logback之间的关系,对于使用及相关配置文件的详细配置不作说明,对于具体的使用参考文章末尾相关参考连接。
最后,送上slf4j和log4j整合使用时的一些参考连接
https://blog.csdn.net/javaloveiphone/article/details/52486257 (log桥接工具jcl-over-slf4j使用,项目排除commons-logging依赖的影响)
https://blog.csdn.net/minicto/article/details/52672472
https://blog.csdn.net/foreverling/article/details/51385128
https://www.cnblogs.com/junzi2099/p/7930268.html#_label6
https://www.cnblogs.com/chenhongliang/p/5312517.html (java经常使用日志框架介绍)