Simple Logging Facade for Java (SLF4J)


slf4j可以看成是对各个日志框架的一种抽象,它提供了一套通用的日志使用接口。


下面是slf4j的几个版本比较:

1.6.0 如果没有绑定底层的日志框架的话,默认会有一个no-operation (nop)logger 的实现

1.7.0 打印方法可以指定参数类型,但是要求jdk5或以上的版本

1.7.5 更快的检索速度,所以推荐使用1.7.5或以上版本

1.7.9 通过设置能自动检测出代码中日志记录器不一致的情况,比如下面这种情况:

  1. package com.acme;
  2. import com.foo.Kangaroo;
  3.  
  4. class Fruit {
  5. Logger logger = LoggerFactory.getLogger(Kangaroo.class);
  6. }

系统就会抛出警告:SLF4J: Detected logger name mismatch. Given name: "com.foo.Kangaroo"; computed name: "com.acme.Fruit".

下面这种情况除外:

  1. class A {
  2. Logger logger = LoggerFactory.getLogger(getClass());
  3. }
  4. class B extends A {
  5. // no mismatch warning will be issued when B is instantiated
  6. // given that class A is a super-type of class B
  7. }

  slf4j / commons logging(jcl) / log4j / logback / java.util.logging(jul)的区别

slf4j和comms logging 都是接口而非实现 常用的实现有:log4j 、logback 、jul 等

查看详细解释

基于slf4j接口各个日志系统实现关系图如下:

使用日志系统时包的搭配如下:

其中jcl-over-slf4j.jar:覆盖jcl、log4j-over-slf4j.jar: 覆盖log4j 、jul-to-slf4j.jar:安装SLF4JHandler必需要用的包


  1.  
  2. 使用slf4j经常会碰到以下几种错误
  1.  

Failed to load class org.slf4j.impl.StaticLoggerBinder

这种情况出现的原因是没有指定具体的底层日志实现,遇到这种情况可以考虑添加如下依赖包中的一种:slf4j-nop.jar slf4j-simple.jarslf4j-log4j12.jarslf4j-jdk14.jar or logback-classic.jar  如果不做日志的操作可以考虑添加slf4j-nop.jar

Multiple bindings were found on the class path

一个项目中出现多个实现,比如同时存在log4j和logback,之前项目开发时就遇到过一种情况,我们日志系统里面使用的是log4j,但是在maven里面引入别的系统用的是logback,由于没有考虑到这种情况,最终在上线的时候内存瞬间被打印出来的日志信息占满。使得上线失败,最后采用清理系统,然后回滚到之前项目的方式才避免了损失。通过一番检查才发现是由于引入的系统用的logback,在项目部署的时候系统会寻找相应的logback的配置信息,但是问题来了,我们项目里面没有logback的配置,只有log4j配置,这个时候logback会按照默认的日志方式去打印,默认的日志级别是debug,最终造成所有的日志信息都被打印出来,下面是个人的一些关于解决项目冲突的总结:

slf4j在绑定日志底层实现时,如果使用Maven的话,Maven默认的加载机制会导致slf4j加载最终绑定pom.xml文件中排在前面的实现。如果非Maven的情况可以考虑成是随机的,由JVM决定:下面是官方的解释:The way SLF4J picks a binding is determined by the JVM and for all practical purposes should be considered random.

解决上面出现的问题有两种方式:

第一方式:删除到不用的日志底层实现jar包,只使用其中之一

第二种方式:排除对于具体日志的实现方式

  1. <dependencies>
  2. <dependency>
  3. <groupId> org.apache.cassandra</groupId>
  4. <artifactId>cassandra-all</artifactId>
  5. <version>0.8.1</version>
  6.  
  7. <exclusions>
  8. <exclusion>
  9. <groupId>org.slf4j</groupId>
  10. <artifactId>slf4j-log4j12</artifactId>
  11. </exclusion>
  12. <exclusion>
  13. <groupId>log4j</groupId>
  14. <artifactId>log4j</artifactId>
  15. </exclusion>
  16. </exclusions>
  17.  
  18. </dependency>
  19. </dependencies>

文章参考:slf4j

log4j与logback

slf4j的更多相关文章

  1. slf4j中的MDC

    slf4j中MDC是什么鬼 slf4j除了trace.debug.info.warn.error这几个日志接口外,还可以配合MDC将数据写入日志.换句话说MDC也是用来记录日志的,但它的使用方式与使用 ...

  2. Atitit.日志系统slf4j的使用

    Atitit.日志系统slf4j的使用 SLF4J: Class path contains multiple SLF4J bindings. SLF4J: Found binding in [jar ...

  3. 用户代理字符串识别工具源码与slf4j日志使用

    User Agent中文名为用户代理,简称 UA,它是一个特殊字符串头,使得服务器能够识别客户使用的操作系统及版本.CPU 类型.浏览器及版本.浏览器渲染引擎.浏览器语言.浏览器插件等.UA也成为了, ...

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

    转自:http://www.blogjava.net/daiyongzhi/archive/2014/04/13/412364.html common-logging是apache提供的一个通用的日志 ...

  5. java.lang.NoClassDefFoundError: Lorg/slf4j/Logger;

    如果你出现类似如下错误 1. Install tomcat7 in my home directory and set up `CATALINA_HOME` environment variable ...

  6. SLF4J: Class path contains multiple SLF4J bindings.

    库冲突导致的异常,由于多次引入SLF4j包导致. It seems you have several implementation of SLF4J; you should exclude all t ...

  7. 使用Slf4j集成Log4j2构建项目日志系统的完美解决方案

    一.背景 最近因为公司项目性能需要,我们考虑把以前基于的log4j的日志系统重构成基于Slf4j和log4j2的日志系统,因为,使用slf4j可以很好的保证我们的日志系统具有良好的兼容性,兼容当前常见 ...

  8. Spring 使用 SLF4J代替 Commons Logging 写日志 异常

    项目的日志更换成slf4j和logback后,发现项目无法启动.错误提示 Caused by: java.lang.NoClassDefFoundError: Lorg/apache/commons/ ...

  9. slf4j的简单介绍

    SLF4J,Simple Logging Facade for JAVA,是一个十分简单的的日志facade,对于不同的日志框架做了一个封装. 对比common logging,Common logg ...

随机推荐

  1. 一次修改闭源 Entity Provider 程序集以兼容新 EntityFramework 的过程

    读完本文你会知道,如何在没有源码的情况下,直接修改一个 DLL 以去除 DLL 上的强命名限制,并在该程序集上直接添加你的“友元程序集(一种特殊的 Attribute,将它应用在程序集上,使得程序集内 ...

  2. HTML5 sessionStorage会话存储

    sessionStorage 是HTML5新增的一个会话存储对象,用于临时保存同一窗口(或标签页)的数据,在关闭窗口或标签页之后将会删除这些数据.本篇主要介绍 sessionStorage(会话存储) ...

  3. Cocos2d Android 环境搭建

    1.在开始之前,需要先准备好资源如下,如果安卓开发环境有了直接装第3.4. 1.JDK      点击下载 (1.6) 2.ADT(已经自带Android SDK)点击下载 3.NDK 点击下载 4. ...

  4. C#多线程之线程池篇3

    在上一篇C#多线程之线程池篇2中,我们主要学习了线程池和并行度以及如何实现取消选项的相关知识.在这一篇中,我们主要学习如何使用等待句柄和超时.使用计时器和使用BackgroundWorker组件的相关 ...

  5. 【原创经验分享】WCF之消息队列

    最近都在鼓捣这个WCF,因为看到说WCF比WebService功能要强大许多,另外也看了一些公司的招聘信息,貌似一些中.高级的程序员招聘,都有提及到WCF这一块,所以,自己也关心关心一下,虽然目前工作 ...

  6. iOS开发之ReactiveCocoa下的MVVM(干货分享)

    最近工作比较忙,但还是出来更新博客了,今天给大家分享一些ReactiveCocoa以及MVVM的一些东西,干活还是比较足的.在之前发表过一篇博文,名字叫做<iOS开发之浅谈MVVM的架构设计与团 ...

  7. Asp.Net WebApi核心对象解析(上篇)

    生活需要自己慢慢去体验和思考,对于知识也是如此.匆匆忙忙的生活,让人不知道自己一天到晚都在干些什么,似乎每天都在忙,但又好似不知道自己到底在忙些什么.不过也无所谓,只要我们知道最后想要什么就行.不管怎 ...

  8. 6_Win7下Chrome主页被流氓网站hao123.com劫持后的解决方法。

    今天安装了一个PDF阅读器,免费的,你懂的,结果自己安装的时候没有将默认的选项取消,就被hao123流氓网站劫持啦. 说实话某免费PDF阅读器还算好的,有一个可以供你选择的项.不想某些软件直接就默认选 ...

  9. 根据ip判断返回城市名称查询当地天气

    <?phpheader("content-type:text/html;charset=utf-8");date_default_timezone_set("Asi ...

  10. js数组去重几种思路

    在一些后台语言中都内置了一些方法来处理数组或集合中重复的数据.但是js中并没有类似的方法,网上已经有一些方法,但是不够详细.部分代码来源于网络.个人总计如下:大致有4种思路 1)使用两次循环比较原始的 ...