slf4j,log4j,logback之间的关系(代码片段)

小小本科生 小小本科生     2022-12-04     535

关键词:

1.SLF4J(Simple logging Facade for Java)

        意思为简单日志门面,它是把不同的日志系统的实现进行了具体的抽象化,只提供了统一的日志使用接口,使用时只需要按照其提供的接口方法进行调用即可,由于它只是一个接口,并不是一个具体的可以直接单独使用的日志框架,所以最终日志的格式、记录级别、输出方式等都要通过接口绑定的具体的日志系统来实现,这些具体的日志系统就有log4j,logback,java.util.logging等,它们才实现了具体的日志系统的功能。

如何使用SLF4J?

        既然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包情况为:

        (1) SLF4J和logback结合使用时需要提供的jar:slf4j-api.jar,logback-classic.jar,logback-core.jar

        (2) SLF4J和log4j结合使用时需要提供的jar:slf4j-api.jar,slf4j-log412.jar,log4j.jar

        (3) SLF4J和JDK中java.util.logging结合使用时需要提供的jar:slf4j-api.jar,slf4j-jdk14.jar

        (4) SLF4J和simple(SLF4J本身提供的一个接口的简单实现)结合使用时需要提供的jar:slf4j-api.jar,slf4j-simple.jar

当然还有其他的日志实现包,以上是经常会使用到的一些。

注意以上slf4j和各日志实现包结合使用时最好只使用一种结合,不然的话会提示重复绑定日志,并且会导致日志无法输出。

 

slf4j-api.jar:对外提供统一的日志调用接口,该接口具体提供的调用方式和方法举例说明:

public class Test 

    //通过LoggerFactory获取Logger实例
  private static final Logger logger = LoggerFactory.getLogger(Tester.class); 

  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?

  •  slf4j是一个日志接口,自己没有具体实现日志系统,只提供了一组标准的调用api,这样将调用和具体的日志实现分离,使用slf4j后有利于根据自己实际的需求更换具体的日志系统,比如,之前使用的具体的日志系统为log4j,想更换为logback时,只需要删除log4j相关的jar,然后加入logback相关的jar和日志配置文件即可,而不需要改动具体的日志输出方法,试想如果没有采用这种方式,当你的系统中日志输出有成千上万条时,你要更换日志系统将是多么庞大的一项工程。如果你开发的是一个面向公众使用的组件或公共服务模块,那么一定要使用slf4的这种形式,这有利于别人在调用你的模块时保持和他系统中使用统一的日志输出。
  • slf4j日志输出时可以使用占位符,如,logger.info("testlog: ", "test"),而如果只使用log4j做日志输出时,只能以logger.info("testlog:"+"test")这种形式,前者要比后者在性能上更好,后者采用+连接字符串时就是new 一个String 字符串,在性能上就不如前者。

2.log4j(log for java)

        Log4j是Apache的一个开源项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件,甚至是套接口服务器、NT的事件记录器、UNIX Syslog守护进程等;我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程。最令人感兴趣的就是,这些可以通过一个配置文件来灵活地进行配置,而不需要修改应用的代码。

如何使用?

  • 引入jar,使用log4j时需要的jar为:log4j.jar。
  • 定义配置文件log4j.properties或log4j.xml
  • 在具体的类中进行使用:
  • 在需要日志输出的类中加入:private static final Logger logger = Logger.getLogger(Tester.class);  //通过Logger获取Logger实例
  • 在需要输出日志的地方调用相应方法即可:logger.debug(“System …..”)

关于如何单独使用log4j,建议详细阅读以下文章:

        https://blog.csdn.net/u012422446/article/details/51199724

        https://blog.csdn.net/azheng270/article/details/2173430/

        http://shmilyaw-hotmail-com.iteye.com/blog/2410764

3.logback

        logback同样是由log4j的作者设计完成的,拥有更好的特性,用来取代log4j的一个日志框架,是slf4j的原生实现(即直接实现了slf4j的接口,而log4j并没有直接实现,所以就需要一个适配器slf4j-log4j12.jar),logback一共有以下几个模块:

  • logback-core:其它两个模块的基础模块
  • logback-classic:它是log4j的一个改良版本,同时它完整实现了slf4j API使你可以很方便地更换成其它日志系统如log4j或JDK14 Logging
  • logback-access:访问模块与Servlet容器集成提供通过Http来访问日志的功能

同样,单独使用它时,需要引入以上jar,然后进行配置文件的配置,最后就是在相关类中进行使用,使用时加入以下语句:

private final static Logger logger = LoggerFactory.getLogger(Test.class);

logger.info("打印日志");

对于logback的使用,详细使用方法及配置推荐阅读以下文章:

        https://www.cnblogs.com/warking/p/5710303.html

4.总结如下:

1、slf4j是java的一个日志门面,实现了日志框架一些通用的api,log4j和logback是具体的日志框架。

2、他们可以单独的使用,也可以绑定slf4j一起使用。

        单独使用,分别调用框架自己的方法来输出日志信息。绑定slf4j一起使用。调用slf4j的api来输入日志信息,具体使用与底层日志框架无关(需要底层框架的配置文件)。显然不推荐单独使用日志框架。假设项目中已经使用了log4j,而我们此时加载了一个类库,而这个类库依赖另一个日志框架。这个时候我们就需要维护两个日志框架,这是一个非常麻烦的事情。而使用了slf4j就不同了,由于应用调用的抽象层的api,与底层日志框架是无关的,因此可以任意更换日志框架。

        这篇文章主要是来帮大家理清 slf4j,log4j,logback之间的关系,对于使用及相关配置文件的详细配置不做说明,对于具体的使用参考文章末尾相关参考链接。

        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常用日志框架介绍)

slf4j,log4j,logback之间的关系(代码片段)

...体的日志系统来实现,这些具体的日志系统就有log4j,logback,java.util.logging等,它们才实现了具体的日志系统的功能。如何使用SLF4J?    既然SLF4J只是一个接口,那么实际使用时必须要结合具体的日志系统来使用,... 查看详情

日志-logback

参考:http://www.importnew.com/22290.html一概述  1.1 LogBack、Slf4j和Log4j之间的关系    1)Slf4j(TheSimpleLoggingFacadefor Java)是一个简单日志门面抽象框架本身只提供了日志FacadeAPI和一个简单的日志类实现,一般常配合Log4j,L... 查看详情

从零开始玩转logback

概述LogBack是一个日志框架,它与Log4j可以说是同出一源,都出自CekiGülcü之手。(log4j的原型是早前由CekiGülcü贡献给Apache基金会的)下载地址:http://logback.qos.ch/download.htmlLogBack、Slf4j和Log4j之间的关系Slf4j是TheSimpleLoggingFacadefor ... 查看详情

log4j+slf4j管理日志项目迁移logback+slf4j

...理要转换成logbacak的日志管理。介于之前并未深究log4j和logback日志,所以做起来也很是头疼,不得不查询资料问别人,才勉强完成,所以记录一下从头的步骤,以供别人参考,有不对地方还请大神斧正。首先提供一下log4j和slf4j以... 查看详情

log4j+logback+slf4j+commons-logging的关系与调试

参考链接:http://www.cnblogs.com/zhuawang/p/3999235.html一、问题背景  由于现在开源框架日益丰富,好多开源框架使用的日志组件不尽相同。存在着在一个项目中,不同的版本,不同的框架共存。导致日志输出异常混乱。虽然也... 查看详情

slf4j与log4j是什麽关系?

...g一样。而log4j是具体的实现(即怎么来打印日志等),和logback是一样的。参考技术A都是用于做日志(log)的两套接口,slf4j.jar和log4j,他们都符合commonlog的标准而制定的。可以说是竞争关系,相对而言,log4j用的相对比较多。Hib... 查看详情

slf4j和logback(代码片段)

问题:由于项目需要,今天弄了很久,SLF4J和Logback 一、SLF4J和Logback和CommonsLogging和Log4j的区别以及在普通的java项目中使用:SLF4J和CommonsLogging类似,充当日志API,Logback和Log4j类似,充当其实现类,为什么有了CommonsLogging和Log4j,又... 查看详情

日志框架--logback(代码片段)

logback背景介绍:SLF4J(SimpleLoggingFacadeforJava)是一个日志API接口,SLF4J提供TRACE,DEBUG,INFO,WARN,ERROR五种级别,而log4j和logback就是对SLF4J的具体实现。logback的性能优于log4j。logback-core:其它两个模块的基础模块logback-classic:它是log4j的一... 查看详情

slf4j,commons-logging,log4j等等日志jar的关系

...是日志的接口,供用户使用,而没有提供实现!  log4j,logback等等才是日志的真正实现。  当我们调用接口时,接口的工厂会自动寻找恰当的实现,返回一个实现的实例给我服务。这些过程都是透明化的,用户不需要进行任... 查看详情

logback最佳实践

参考技术ALogback是由log4j创始人设计的一个开源日志组件。LogBack被分为3个组件,logback-core,logback-classic和logback-access。Logback是要与SLF4J结合起来。这两个组件的官方网站如下:logback官方网站:logback官方网站SLF4J官方网站:SLF4J官方... 查看详情

logback与log4j比较

更快的执行速度:基于我们先前在log4j上的工作,logback重写了内部的实现,在某些特定的场景上面,甚至可以比之前的速度快上10倍。在保证logback的组件更加快速的同时,同时所需的内存更加少。logback-classic非常自然的实现了SLF... 查看详情

springbootlogback日志组件使用(代码片段)

一logback简介    Logback是一个开源日志组件。Logback一般和SLF4结合起来使用。外层使用SLF4J,里面的实现是logback。什么意思,简单来说我们使用层看到的是SLF4J。我们使用的时候就是和SLF4J提供的一些api打交道。    我们可能... 查看详情

捕获异常之使用slf4j和logback(代码片段)

...,搭配使用非常便于开发。有的童鞋可能还听说过SLF4J和Logback。这两个东东看上去也像日志,它们又是啥?其实SLF4J类似于CommonsLogging,也是一个日志接口,而Logback类似于Log4j,是一个日志的实现。为什么有了CommonsLogging和Log4j,... 查看详情

java日志组件介绍(common-logging,log4j,slf4j,logback)

logback--官网:​​http://logback.qos.ch/manual/configuration.html​​ common-loggingcommon-logging是apache提供的一个通用的日志接口。用户可以自由选择第三方的日志组件作为具体实现,像log4j,或者jdk自带的logging,common-logging会通过动态查... 查看详情

log4j,log4j2,logback,slf4j日志学习

日志学习笔记Log4jLog4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、数据库等;我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,我们能够更加细致... 查看详情

java#在项目中使用slf4j+logback来记录日志(代码片段)

...ACE有关系统流程的更多详细信息SLF4J和Log4j的关系:1.2Logback概述Logback分为三个不同的模块,logback-core(核心代码模块),logback-classic(log4j的一个改良版本,同时实现了slf4j的接口,这样如果之后要... 查看详情

logback使用

logback简介   Slf4j是TheSimpleLoggingFacadeforJava的简称,是一个简单日志门面抽象框架,它本身只提供了日志FacadeAPI和一个简单的日志类实现,一般常配合Log4j,LogBack,java.util.logging使用。Slf4j作为应用层的Log接入时,程序可... 查看详情

最全的springboot+logback日志配置教程

...志系统是必不可少的,目前比较流行的日志框架有log4j、logback等,可能大家还不知道,这两个框架的作者是同一个人,Logback旨在作为流行的log4j项目的后续版本,从而恢复log4j离开的位置。另外slf4j(SimpleLoggingFacadeforJava)则是一个... 查看详情