常用日志使用方式(slf4j,logback,log4j,common-log)

一、常用日志工具包

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>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值