zoukankan      html  css  js  c++  java
  • slf4j日志系统

    定义:

    slf4j是一个用于日志系统的简单Facade(外观),允许最终用户在部署其应用时使用其所希望的日志系统。而在使用slf4j的时候,不需要在代码中或配置文件中指定你打算使用那个具体的日志系统,slf4j提供了统一的记录日志的接口,只要按照其提供的方法记录即可,最终日志的格式、记录级别、输出方式等通过具体日志系统的配置来实现,因此可以在应用中灵活切换日志系统。

     

    使用:

    在系统开发中,统一按照slf4j的API进行开发,在部署时,选择不同的日志系统包,即可自动转换到不同的日志系统上。比如:选择JDK自带的日志系统,则只需要将slf4j-api-1.6.1.jar和slf4j-jdk14-1.6.1.jar放置到classpath中即可,如果中途无法忍受JDK自带的日志系统了,想换成log4j的日志系统,仅需要用slf4j-log4j12-1.6.1.jar替换slf4j- jdk14-1.6.1.jar即可(需要log4j的jar及配置文件log4j.properties文件),也可以使用slg4j提供的 simple log,slf4j-simple-1.6.1.jar替换slf4j-jdk14-1.6.1.jar。

     

    实例:

    1)使用JDK自带的log输出

        在classpath中加入slf4j-api-1.6.1.jar和slf4j-jdk14-1.6.1.jar两个包,然后运行main函数,输出信息如下:     

      Java代码 

        1 2010-2-23 11:57:28 com.test.Slf4jTest testLog     

        2 信息this is a test log    

        2010-2-23 11:57:28 com.test.Slf4jTest testLog  

        信息: this is a test log 

     

    (2)使用slg4j提供的simple log
        slf4j-simple-1.6.1.jar替换slf4j-jdk14-1.6.1.jar,选择使用slf4j提供的simple log,输出信息如下:

        Java代码 

        3 [main] INFO com.test.Slf4jTest - this is a test log    

     

    3log4j日志输出
        用slf4j-log4j12-1.6.1.jar替换slf4j-simple-1.6.1.jar(记得classpath也需要增加log4j依赖jar包),同时增加一个log4j.properties文件
       我们需要修改下main方法,加载一下log4j.properties,如;  

      Java代码 

        public static void main(String[] args) {        

          System.setProperty("log4j.configuration", "log4j.properties");        

          Slf4jTest slf = new Slf4jTest();        

          slf.testLog();        

        }   

        public static void main(String[] args) {     

             System.setProperty("log4j.configuration", "log4j.properties");     

             Slf4jTest slf = new Slf4jTest();     

              slf.testLog();     

          }


    这样就可以以log4j的方式输出了。

    4)日志系统绑定原理
    在应用中,通过LoggerFactory类的静态getLogger()获取logger。通过查看该类的代码可以看出,最终是通过StaticLoggerBinder.SINGLETON.getLoggerFactory()方法获取LoggerFactory然后,在通过该具体的LoggerFactory来获取logger的。类org.slf4j.impl.StaticLoggerBinder并不在 slf4j-api-1.6.1.jar包中,仔细查看每个与具体日志系统对应的jar包,就会发现,相应的jar包都有一个 org.slf4j.impl.StaticLoggerBinder的实现,不同的实现返回与该日志系统对应的LoggerFactory,因此就实现了所谓的静态绑定,达到只要选取不同jar包就能简单灵活配置的目的。 

  • 相关阅读:
    JDBC操作数据库的步骤 ?
    switch 是否能作用在 byte 上,是否能作用在 long 上, 是否能作用在 String 上?
    有哪些不同类型的IOC(依赖注入)方式?
    ApplicationContext通常的实现是什么?
    如何给Spring 容器提供配置元数据?
    一个”.java”源文件中是否可以包含多个类(不是内部类)? 有什么限制?
    数据库连接(Database link)?
    你怎样定义类的作用域?
    JSP的常用指令有哪些?
    Mapper 编写有哪几种方式?
  • 原文地址:https://www.cnblogs.com/shz365/p/3513455.html
Copyright © 2011-2022 走看看