Java Hour 46 SLF4J
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的更多相关文章
- 纯Java配置使用slf4j配置log4j
工程目录如下 代码里面用的是slf4j,但是想要用log4j来管理日志,就得添加slf4j本来的jar,然后添加log4j和slf4j箱关联的jar即可. 如果是maven项目的话添加下面的依赖即可 ...
- java日志框架slf4j与log4j
日志记录自然是非常重要的,但恐怕能记住slf4j与log4j等日志框架配置的人就很少了,这个东西不难,只是配置好后很少会去动它,开发新项目一般也是从其他项目拷贝,或者参照文档 废话不多说,先说log4 ...
- Java日志框架Slf4j+Log4j入门
一.日志系统介绍 slf4j,即简单日志门面(Simple Logging Facade for Java),不是具体的日志解决方案,它只服务于各种各样的日志系统.简答的讲就是slf4j是一系列的日志 ...
- java日志-纯Java配置使用slf4j配置log4j(转)
工程目录如下 代码里面用的是slf4j,但是想要用log4j来管理日志,就得添加slf4j本来的jar,然后添加log4j和slf4j箱关联的jar即可. 如果是maven项目的话添加下面的依赖即可 ...
- java日志之slf4j与logback简单使用
最近在开发遇到日志是使用slf4j与logback.xml的配置,所以就记录下来了. 1.导入这几个jar包: Logback 分为三个模块:logback-core,logback-classic, ...
- Java日志:集成slf4j和logback
Java日志方案有很多,包括:java.util.logging.Apache的commons-logging和log4j.slf4j以及logback. 一个大型项目会用到众多第三方jar包,这些j ...
- Java日志之Slf4j,Log4J,logback原理总结
几乎任何应用,一定是需要日志的. 那么,面对种类繁多的日志框架和配置,我们该何去何从? 1.前奏:我是在研究mybatis源码的过程中才意识到需要搞明白日志原理这回事,因为mybatis(和一些其他开 ...
- Java日志框架SLF4J和log4j以及logback的联系和区别
1.SLF4J(Simple logging Facade for Java) 意思为简单日志门面,它是把不同的日志系统的实现进行了具体的抽象化,只提供了统一的日志使用接口,使用时只需要按照其提供的接 ...
- Java日志使用slf4j 配置log4j后,有日志文件 但日志文件内容为空
SLF4J的全称是Simple Logging Facade for Java,即简单日志门面. SLF4J并不是具体的日志框架,而是作为一个简单门面服务于各类日志框架,如java.util.logg ...
随机推荐
- --hdu 1114 Piggy-Bank(完全背包)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1114 AC code: #include<bits/stdc++.h> using nam ...
- LINUX渗透与提权总结
本文为Linux渗透与提权技巧总结篇,旨在收集各种Linux渗透技巧与提权版本,方便各位同学在日后的渗透测试中能够事半功倍. Linux 系统下的一些常见路径: 001 /etc/passwd 002 ...
- git小结
1.创建本地与远程分支 先创建远程分支,再创建本地分支,再将本地分支与远程分支关联git fetch 获取远程分支git checkout remote_branch 或者 git checkout ...
- MySql 创建只读账号
GRANT Select ON *.* TO reader@192.168.1.123 IDENTIFIED BY "123456" GRANT 可以立刻生效 在mysql 5 ...
- 三大框架ssh
一.hibernate a.实体类+映射 b.lib hibernate包+oracle包(oracle安装里找) 映射:从类入手class+属性 a.映射的头文件在:hibernate3.jar- ...
- Log4Net日志记录两种方式
简介 log4net库是Apache log4j框架在Microsoft .NET平台的实现,是一个帮助程序员将日志信息输出到各种目标(控制台.文件.数据库等)的工具. log4net是Ap ...
- 再谈对协变和逆变的理解(Updated)
去年写过一篇博客谈了下我自己对协变和逆变的理解,现在回头看发现当时还是太过“肤浅”,根本没理解.不久前还写过一篇“黑”Java泛型的博客,猛一回头又是“肤浅”,今天学习Java泛型的时候又看到了协变和 ...
- 详解mysql int类型的长度值问题
我的朋友海滨问我mysql在建表的时候int类型后的长度代表什么? 是该列允许存储值的最大宽度吗? 为什么我设置成int(1), 也一样能存10,100,1000呢. 当时我虽然知道int(1),这个 ...
- 【云计算】ubuntu下docker安装配置指南
Docker Engine安装配置 以下描述仅Docker在Ubuntu Precise 12.04 (LTS).Ubuntu Trusty 14.04 (LTS).Ubuntu Wily 15.10 ...
- MSSQL 2008错误提示:更改对于登录sa失败
MSSQL 2008错误提示:更改对于登录sa失败: 使用Windows方式登录数据库后,执行以下命令: EXEC sp_password null,"123456"," ...