SLF4J,Simple Logging Facade for JAVA,是一个十分简单的的日志facade,对于不同的日志框架做了一个封装。
对比common logging,Common logging 有一个问题就是对于不同的ClassLoader 的Invalid class loader hierarchy problem,当在OSGI这种不同Bundle不同ClassLoader中使用时,会造成很很大困难。slf4j不依赖于任何的特定的Classloader,slf4j在编译时绑定一个且仅能使用一个日志框架。原文(SLF4J does not rely on any special class loader machinery. In fact, each SLF4J binding is hardwired at compile time to use one and only one specific logging framework.)这就意味着slf4j是静态绑定的。由于slf4j是静态绑定的,所以在速度上对比common logging也有一定的优势。
 
下面是slf4j官方网站给出的slf4j与其他的日志框架适配的图示。
 
 
可以看到slf4j在设计上非常简单,一个slf4j的API,一个与日志框架的Adapter或者本地实现。
使用slf4j也非常简单:
 
  private static Logger logger = LoggerFactory.getLogger(Login.class);
private String getBusinessType(String xml){
String code = extractCodeFrom(xml);
if(logger.isDebugEnabled()){
logger.debug("Code:{}", code);
}
return codeMapType(code);
}

slf4j Adapter利用java的SPI 机制,对于每一个slf4j的日志的适配包,都会是一个SLF4jServiceProvider的实现类,以常用的log4j来看,从下图可以看到,slf4j-log4j12的适配包,在META-INF/services/下可以看到服务的配置文件;

配置文件表示log4j的provider类为org.slf4j.log4j12.Log4j12ServiceProvider

查找到对于的绑定时候,slf4j会检查相应的绑定是否多于一个,若多于一个,则会输出警告,不过,仅仅输出警告而已,且slf4j会随机获取一个,获取的顺序取决于适配包的加载顺序,但是这样就不能确定是不是用户想要的一个日志框架了,所以,仅添加一个日志的适配包是一个的选择。

适配的方式让更换实际的日志框架变得十分简单,仅仅需要将对于的日志框架的适配包更换便能更换整个日志的框架了。例如要将log4j替换为logback仅仅需要在maven的pom.xml中将log4j的适配包的依赖
 
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.7.5</version>
</dependency>

更换为logback适配包的依赖

<dependency>
<groupId>org.slf4j</groupId>
<artifactId>jcl-over-slf4j</artifactId>
<version>1.7.5</version>
</dependency>

这样就可以替换掉日志框架了。

 
只存在一个绑定时,对每一个可适配的日志框架,slf4j会创建对应的日志工厂,比如绑定log4j时会创建Log4jLoggerFactory,Log4jLoggerFactory会实例化slf4j与log4j的适配器Log4jLoggerAdapter,Log4jLoggerAdapter实例化log4j的实例,并使用FormattingTuple将参数填充到信息中,将日志按照Log4j的layout格式输出。这样就完成了slf4j到log4j的转换了。

slf4j的简单介绍的更多相关文章

  1. Log4j slf4j 配置简单介绍

    Log4j slf4j 配置简单介绍 先借鉴一篇很好的文章 为什么要使用SLF4J而不是Log4J import org.slf4j.Logger; import org.slf4j.LoggerFa ...

  2. slf4j的简单用法以及与log4j的区别

    之前在项目中用的日志记录器都是log4j的日志记录器,可是到了新公司发现都是slf4j,于是想着研究一下slf4j的用法. 注意:每次引入Logger的时候注意引入的jar包,因为有Logger的包太 ...

  3. JSR 303 - Bean Validation 简单介绍及用法

    一.JSR-303简单介绍 JSR-303 是 JAVA EE 6 中的一项子规范.叫做 Bean Validation,官方參考实现是Hibernate Validator. 此实现与 Hibern ...

  4. lombok 注解简单介绍

    一.Lombok 的简单介绍和使用 Lombok是一个可以帮助我们简化 Java 代码编写的工具类,通过采用注解的方式简化了 JavaBean 的编写,使我们写的类更加简洁. 1. 添加 Lombok ...

  5. [原创]关于mybatis中一级缓存和二级缓存的简单介绍

    关于mybatis中一级缓存和二级缓存的简单介绍 mybatis的一级缓存: MyBatis会在表示会话的SqlSession对象中建立一个简单的缓存,将每次查询到的结果结果缓存起来,当下次查询的时候 ...

  6. 利用Python进行数据分析(7) pandas基础: Series和DataFrame的简单介绍

    一.pandas 是什么 pandas 是基于 NumPy 的一个 Python 数据分析包,主要目的是为了数据分析.它提供了大量高级的数据结构和对数据处理的方法. pandas 有两个主要的数据结构 ...

  7. 利用Python进行数据分析(4) NumPy基础: ndarray简单介绍

    一.NumPy 是什么 NumPy 是 Python 科学计算的基础包,它专为进行严格的数字处理而产生.在之前的随笔里已有更加详细的介绍,这里不再赘述. 利用 Python 进行数据分析(一)简单介绍 ...

  8. yii2的权限管理系统RBAC简单介绍

    这里有几个概念 权限: 指用户是否可以执行哪些操作,如:编辑.发布.查看回帖 角色 比如:VIP用户组, 高级会员组,中级会员组,初级会员组 VIP用户组:发帖.回帖.删帖.浏览权限 高级会员组:发帖 ...

  9. angular1.x的简单介绍(二)

    首先还是要强调一下DI,DI(Denpendency Injection)伸手获得,主要解决模块间的耦合关系.那么模块是又什么组成的呢?在我看来,模块的最小单位是类,多个类的组合就是模块.关于在根模块 ...

随机推荐

  1. eclipse自动排版JSP问题

    eclipse自动排版JSP非常难看,标签每行显示不完整,开发时很难受,下面设置一下这个就好多了: window-->preferences-->Web-->HTML Files-- ...

  2. (转)springMVC+mybatis+ehcache详细配置

    一. Mybatis+Ehcache配置 为了提高MyBatis的性能,有时候我们需要加入缓存支持,目前用的比较多的缓存莫过于ehcache缓存了,ehcache性能强大,而且位各种应用都提供了解决方 ...

  3. 2016年6月20日 JAVA知识框架

    基于 J2EE 列举的知识架构,大体列举开发基础知识.帮助我随时查缺补漏,奉行好记性不如烂笔头.写了这该随笔,以便后续查询. 1  JAVA简介 2  JAVA编程环境 3  JAVA基本编程结构 4 ...

  4. Oracle SQL的硬解析和软解析

    我们都知道在Oracle中每条SQL语句在执行之前都需要经过解析,这里面又分为软解析和硬解析.在Oracle中存在两种类型的SQL语句,一类为 DDL语句(数据定义语言),他们是从来不会共享使用的,也 ...

  5. [LeetCode] Best Time to Buy and Sell Stock II

    Say you have an array for which the ith element is the price of a given stock on day i. Design an al ...

  6. zeromq rpc原型

    /* Asynchronous request-reply single-threaded server in Python that spawns a request handler each ti ...

  7. HEAP CORRUPTION DETECTED :after Normal block 错误

    http://blog.csdn.net/zhccl/article/details/7889590

  8. 利用C# Winform做Windows系统任务栏

    最近公司做一个考试系统,需要一个答题栏,要求:占用屏幕上方一部分区域,而且始终置顶,当其他窗口最大化时"答题栏"始终置前并且不遮挡最大化窗口的任何部分!就像windows任务栏一样 ...

  9. app后端设计--总目录 (转)

    特此说明,我转载的!!! app后端设计(1)--api app后端设计(2)--xmpp的使用 app后端设计(3)--短信,邮件,推送服务 app后端设计(4)-- 通讯的安全性 app后端设计( ...

  10. JQuery的无缝滚动

    图片无缝向左滚动的代码如下:   <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "h ...