SLF4J(Simple Logging Facade for Jave).

上个章节在配置启动项目后,会报一个奇怪的错误,一开始以为是Maven 依赖有冲突,其实是和slf4j 密切相关的。

本文原链接地址http://www.cnblogs.com/bnbqian/

46.1 最常见的Error Message

SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
  SLF4J: Defaulting to no-operation (NOP) logger implementation
  SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details.
这个错误其实再明显不过了,就是说在当前class path 下找不到 slf4j 的binding.
至于binding 是什么,和slf4j 是什么关系,这个就要从这个应用的定位开始说起。

46.2 slf4j 究竟是什么

slf4j 的f 的含义就是外观或者说是一种抽象,这就对了,slf4j 是对各种各样主流log 框架的一个抽象接口。

比如说 java.util.logging, logback, log4j.

slf4j 其实只有一个jar 包,那就是 slf4j-api-1.7.5.jar.

自从1.6.0 版本开始,如果么有找到对应的绑定,slf4j 将会默认转向无操作的实现,也就是不输出任何log.

46.3 slf4j 的binding 究竟是什么

就像上面所说的,slf4j 只是接口,能够支持各种log 框架的工作。但是slf4j 和log 框架之间,需要一个类似与转换器一样的东西。

slf4j 和每一个log 框架的整合都是通过这个转换器的。

例如:

slf4j-log4j12-1.7.5.jar 就是一个连接log4j.jar 的binding

slf4j-jdk14-1.7.5 就是一个连接JDK1.4 logging 的binding

slf4j-simple-1.7.5.jar 简单的将日志输出到System.err, 适合小程序的binding

slf4j-nop-1.7.5.jar 这个东东就是啥都不做

只要通过替换这个binding 就可以直接替换对应的日志框架,自然就happy了。

46.4 日志框架开发应该依赖slf4j-api, 而不该依赖binding

这个是显而易见的,slf4j 设计的目的就是可以随时随地切换日志组件,任何框架都不该依赖于binding.

也就是这个原因,在Maven 中添加了Hibernate-core 后,并不会下载对应的binding.

以至于程序刚开始的时候会有个简单的信息告诉我们日志模块被切到了nop.

46.5 Log4j

我们的项目已经添加了log4j 的 jar 包,接下去自然加上对应的binding 就可以了。

折腾了好久,中央仓库可能暂时升天了,找替换仓库。

<repositories>
        <repository>
            <id>central</id>
            <name>replace</name>
            <url>http://mirrors.ibiblio.org/maven2/</url>
            <snapshots>
                <enabled>false</enabled>
            </snapshots>
        </repository>

加上binding

<dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-log4j12</artifactId>
            <version>1.7.2</version>
        </dependency>

日志终于能够正常输出了!

有些时候不要去中央仓库下载jar 包了,手动安装jar 包到本地仓库的技能我觉得也是必须的。

手动安装目前暂时不需要了,先标记个参考文章吧,下次可以阅读 http://www.blogjava.net/fancydeepin/archive/2012/06/12/380605.html 说白了其实就是下载包,然后一个命令行,今天的时间结束。

Java Hour 46 SLF4J的更多相关文章

  1. 纯Java配置使用slf4j配置log4j

    工程目录如下 代码里面用的是slf4j,但是想要用log4j来管理日志,就得添加slf4j本来的jar,然后添加log4j和slf4j箱关联的jar即可. 如果是maven项目的话添加下面的依赖即可 ...

  2. java日志框架slf4j与log4j

    日志记录自然是非常重要的,但恐怕能记住slf4j与log4j等日志框架配置的人就很少了,这个东西不难,只是配置好后很少会去动它,开发新项目一般也是从其他项目拷贝,或者参照文档 废话不多说,先说log4 ...

  3. Java日志框架Slf4j+Log4j入门

    一.日志系统介绍 slf4j,即简单日志门面(Simple Logging Facade for Java),不是具体的日志解决方案,它只服务于各种各样的日志系统.简答的讲就是slf4j是一系列的日志 ...

  4. java日志-纯Java配置使用slf4j配置log4j(转)

    工程目录如下 代码里面用的是slf4j,但是想要用log4j来管理日志,就得添加slf4j本来的jar,然后添加log4j和slf4j箱关联的jar即可. 如果是maven项目的话添加下面的依赖即可 ...

  5. java日志之slf4j与logback简单使用

    最近在开发遇到日志是使用slf4j与logback.xml的配置,所以就记录下来了. 1.导入这几个jar包: Logback 分为三个模块:logback-core,logback-classic, ...

  6. Java日志:集成slf4j和logback

    Java日志方案有很多,包括:java.util.logging.Apache的commons-logging和log4j.slf4j以及logback. 一个大型项目会用到众多第三方jar包,这些j ...

  7. Java日志之Slf4j,Log4J,logback原理总结

    几乎任何应用,一定是需要日志的. 那么,面对种类繁多的日志框架和配置,我们该何去何从? 1.前奏:我是在研究mybatis源码的过程中才意识到需要搞明白日志原理这回事,因为mybatis(和一些其他开 ...

  8. Java日志框架SLF4J和log4j以及logback的联系和区别

    1.SLF4J(Simple logging Facade for Java) 意思为简单日志门面,它是把不同的日志系统的实现进行了具体的抽象化,只提供了统一的日志使用接口,使用时只需要按照其提供的接 ...

  9. Java日志使用slf4j 配置log4j后,有日志文件 但日志文件内容为空

    SLF4J的全称是Simple Logging Facade for Java,即简单日志门面. SLF4J并不是具体的日志框架,而是作为一个简单门面服务于各类日志框架,如java.util.logg ...

随机推荐

  1. fork Bomb

    类Unix ;(){:|:&};: windows %0|%0

  2. WinForm TextBox 焦点停留到文本最后

    最近写个 WinForm 项目,TextBox 控件有内容的时候,获取焦点,光标总是在最前面,很不便于输入.那怎么样让光标停留到最后呢?如下代码可以实现:            this.txtBox ...

  3. Zabbix 监控 Nginx 状态

    简介: 如何使用 Zabbix 监控 Nginx 状态 ? 1.获取 Nginx 状态( HTTP Stub Status ) shell > /usr/local/nginx/sbin/ngi ...

  4. MapReduce中TextInputFormat分片和读取分片数据源码级分析

    InputFormat主要用于描述输入数据的格式(我们只分析新API,即org.apache.hadoop.mapreduce.lib.input.InputFormat),提供以下两个功能: (1) ...

  5. cocos2d-x避免手动修改android.mk文件来编译

    编辑android.mk文件,替换为如下内容 LOCAL_PATH := $(call my-dir) LOCAL_PATH := $(call my-dir) include $(CLEAR_VAR ...

  6. IOC和AOP的基础原理

    IoC(Inversion of Control)就是由容器控制程序之间的关系,而非传统实现中,由程序代码直接操控.这也就是所谓“控制反转”的概念所在.控制权由应用代码中转到了外部容器,控制权的转移是 ...

  7. 淘宝(阿里百川)手机客户端开发日记第二篇 android首页之顶部轮播特效制作 (二)

    1.我们来设计flash_slide.xml 布局,这个xml主要做成模块化,方便其它的activity可以动态去调用. flash_slide.xml内容如下: <?xml version=& ...

  8. 使用nginx lua实现网站统计中的数据收集

    导读网站数据统计分析工具是各网站站长和运营人员经常使用的一种工具,常用的有 谷歌分析.百度统计和腾讯分析等等.所有这些统计分析工具的第一步都是网站访问数据的收集.目前主流的数据收集方式基本都是基于ja ...

  9. Xcode 5.0.2 下载地址

    下载地址:http://adcdownload.apple.com/Developer_Tools/xcode_5.0.2/xcode_5.0.2.dmg command_line_tools_os_ ...

  10. IOS 页面之间的跳转

    1.UINavigationController popToViewController 对应popViewControllerAnimated: 也可以使用: [self.navigationCon ...