zoukankan      html  css  js  c++  java
  • Java日志框架介绍和 Slf4j 使用

    Java常用的日志框架介绍

    • 1996年早期,欧洲安全电子市场项目组决定编写它自己的程序跟踪API(Tracing API)。经过不断的完善,这个API终于成为一个十分受欢迎的Java日志软件包,即Log4j。后来Log4j成为Apache基金会项目中的一员。
    • 期间Log4j近乎成了Java社区的日志标准。据说Apache基金会还曾经建议Sun引入Log4j到java的标准库中,但Sun拒绝了。
    • 2002年Java1.4发布,Sun推出了自己的日志库JUL(Java Util Logging),其实现基本模仿了Log4j的实现。在JUL出来以前,Log4j就已经成为一项成熟的技术,使得Log4j在选择上占据了一定的优势。
    • 接着,Apache推出了Jakarta Commons Logging,JCL只是定义了一套日志接口(其内部也提供一个Simple Log的简单实现),支持运行时动态加载日志组件的实现,也就是说,在你应用代码里,只需调用Commons Logging的接口,底层实现可以是Log4j,也可以是Java Util Logging。
    • 后来(2006年),Ceki Gülcü不适应Apache的工作方式,离开了Apache。然后先后创建了Slf4j (日志门面接口,类似于Commons Logging)和 Logback (Slf4j的实现)两个项目,并回瑞典创建了QOS公司,QOS官网上是这样描述Logback的:The Generic,Reliable Fast&Flexible Logging Framework(一个通用,可靠,快速且灵活的日志框架)。
    • 现今,Java日志领域被划分为两大阵营:Commons Logging阵营和Slf4j阵营。

    【常用组合】

    • 比较常用的组合使用方式是Slf4j与Logback组合使用,Commons Logging与Log4j组合使用。
    • Logback必须配合Slf4j使用。由于Logback和Slf4j是同一个作者,其兼容性不言而喻。

    项目中日志框架的选择

    如果是在一个新的项目中建议使用Slf4j与Logback组合,这样有如下的几个优点。

    • Slf4j实现机制决定Slf4j限制较少,使用范围更广。由于Slf4j在编译期间,静态绑定本地的LOG库使得通用性要比Commons Logging要好。
    • Logback拥有更好的性能。Logback声称:某些关键操作,比如判定是否记录一条日志语句的操作,其性能得到了显著的提高。这个操作在Logback中需要3纳秒,而在Log4J中则需要30纳秒。LogBack创建记录器(logger)的速度也更快:13毫秒,而在Log4J中需要23毫秒。更重要的是,它获取已存在的记录器只需94纳秒,而Log4J需要2234纳秒,时间减少到了1/23。跟JUL相比的性能提高也是显著的。
    • Commons Logging开销更高
    // 在使Commons Logging时为了减少构建日志信息的开销,通常的做法是
    if(log.isDebugEnabled()){
      log.debug("User name: " +
        user.getName() + " buy goods id :" + good.getId());
    }
    
    // 在Slf4j阵营,你只需这么做:
    log.debug("User name:{} ,buy goods id :{}", user.getName(),good.getId());
    
    // 也就是说,Slf4j把构建日志的开销放在了它确认需要显示这条日志之后,减少内存和Cup的开销,使用占位符号,代码也更为简洁
    
    • Logback文档免费。Logback的所有文档是全面免费提供的,不象Log4J那样只提供部分免费文档而需要用户去购买付费文档。

    日志级别

    slf4j的日志级别分为五种

      info、debug、error、warn、trane

    常用的是这是三个。

    • info 一般处理业务逻辑的时候使用,就跟 system.err打印一样,用于说明此处是干什么的。slf4j使用的时候是可以动态的传参的,使用占位符 {} 。后边一次加参数,会挨个对应进去。

    • debug: 一般放于程序的某个关键点的地方,用于打印一个变量值或者一个方法返回的信息之类的信息

    • error: 用户程序报错,必须解决的时候使用此级别打印日志。

    不常用的有:

    • warn:警告,不会影响程序的运行,但是值得注意。

    • trane: 一般不会使用,在日志里边也不会打印出来,好像是很低的一个日志级别。

    Slf4j 使用

    pom核心配置如下

      <dependencies>
        <dependency>
          <groupId>org.projectlombok</groupId>
    	  <artifactId>lombok</artifactId>
    	</dependency>
        <!--只有slf4j-api依赖-->
        <dependency>
          <groupId>org.slf4j</groupId>
          <artifactId>slf4j-api</artifactId>
          <version>1.7.13</version>
        </dependency>
      </dependencies>
    

    程序入口类如下

    import org.slf4j.Logger;
    import org.slf4j.LoggerFactory;
    
    /**
     * slf4j demo
     */
    public class Demo1 {
        final static Logger logger = LoggerFactory.getLogger(Demo1.class);
    
        public static void main(String[] args) {
            logger.info("Hello world!");
        }
    }
    

    也可以在类上添加@slf4j注解,随后可以直接在方法体里边使用log.方法,调用出来。

    import lombok.extern.slf4j.Slf4j;
    
    /**
     * @slf4j demo
     */
    @Slf4j
    public class Demo1 {
    
        public static void main(String[] args) {
            log.info("Hello world!");
        }
    }
    

    注:如果在idea里边添加了@slf4j注解之后,无法使用 log.方法。则需要去下载一个插件。

    推荐一篇大佬对 Slf4j 的介绍:https://www.cnblogs.com/xrq730/p/8619156.html


  • 相关阅读:
    子矩阵
    [Ahoi2008]Meet 紧急集合
    立体图
    CF933B A Determined Cleanup
    CF746G New Roads
    树的重量
    CF519E A and B and Lecture Rooms
    矩阵
    深入浅出乘法逆元
    20180519模拟赛T2——pretty
  • 原文地址:https://www.cnblogs.com/luler/p/15232704.html
Copyright © 2011-2022 走看看