zoukankan      html  css  js  c++  java
  • 日志框架之Slf4j整合Logback

     

    什么是Slf4j ?

    Slf4J,即简单日志门面(Simple Logging Facade for Java),不是具体的日志解决方案,它只服务于各种各样的日志系统。按照官方的说法,Slf4J是一个用于日志系统的简单Facade,允许最终用户在部署其应用时使用其所希望的日志系统。

    从某种程度上,Slf4J有点类似JDBC,不过比JDBC更简单,在JDBC中,你需要指定驱动程序,而在使用Slf4J的时候,不需要在代码中或配置文件中指定你打算使用那个具体的日志系统。如同使用JDBC基本不用考虑具体数据库一样,Slf4J提供了统一的记录日志的接口,只要按照其提供的方法记录即可,最终日志的格式、记录级别、输出方式等通过具体日志系统的配置来实现,因此可以在应用中灵活切换日志系统。

    什么是Logback?

    Logback是由log4j创始人设计的又一个开源日志组件。Logback当前分成三个模块:

    • Logback-core
    • Logback- classic
    • Logback-access

    Logback-core是其它两个模块的基础模块。Logback-classic是log4j的一个 改良版本。此外Logback-classic完整实现SLF4J API使你可以很方便地更换成其它日志系统如log4j或JDK14 Logging。Logback-access访问模块与Servlet容器集成提供通过Http来访问日志的功能。

    补充:门面模式,是指提供一个统一的接口去访问多个子系统的多个不同的接口,它为子系统中的一组接口提供一个统一的高层接口。使得子系统更容易使用。

    Slf4j就是门面,Logback就是她的子系统。

    1.快速入门

    1.1 添加依赖

    此处额外添加了 Junit依赖,用于单元测试,直观展示效果

    关于Junit 可以参考这篇:https://blog.csdn.net/qq_36110736/article/details/107774507

    1.  
      <!-- Slf4j 依赖 -->
    2.  
      <dependency>
    3.  
      <groupId>org.slf4j</groupId>
    4.  
      <artifactId>slf4j-api</artifactId>
    5.  
      <version>1.7.30</version>
    6.  
      </dependency>
    7.  
      <!-- logback 依赖 -->
    8.  
      <dependency>
    9.  
      <groupId>ch.qos.logback</groupId>
    10.  
      <artifactId>logback-classic</artifactId>
    11.  
      <version>1.2.3</version>
    12.  
      </dependency>
    13.  
      <!-- Junit依赖 用于单元测试-->
    14.  
      <dependency>
    15.  
      <groupId>junit</groupId>
    16.  
      <artifactId>junit</artifactId>
    17.  
      <version>4.13</version>
    18.  
      </dependency>

    1.2 具体实现

    1.  
      import org.junit.Test;
    2.  
      import org.slf4j.Logger;
    3.  
      import org.slf4j.LoggerFactory;
    4.  
       
    5.  
      public class Slf4jTest {
    6.  
      public static final Logger LOGGER = LoggerFactory.getLogger(Slf4jTest.class);
    7.  
       
    8.  
      @Test
    9.  
      public void test01(){
    10.  
      //日志输出
    11.  
      LOGGER.error("error");
    12.  
      LOGGER.warn("wring");
    13.  
      LOGGER.info("info");
    14.  
      LOGGER.debug("debug");
    15.  
      LOGGER.trace("trance");
    16.  
       
    17.  
      //占位符输出
    18.  
      String name = "bysen";
    19.  
      Integer age = 24;
    20.  
      LOGGER.info("姓名{},年龄{}",name,age);
    21.  
       
    22.  
      //异常处理
    23.  
      try{
    24.  
      int i =1/0;
    25.  
      }catch (Exception e){
    26.  
      LOGGER.error("发生异常:",e);
    27.  
      }
    28.  
      }
    29.  
       
    30.  
      }

    1.3 运行结果

    补充:Slf4j日志级别,重要程度由上到下

    1.  error: 用户程序报错,必须解决的时候使用此级别打印日志。
    2. warn:警告,不会影响程序的运行,但是值得注意。
    3. info  一般处理业务逻辑的时候使用,就跟 system.err打印一样,用于说明此处是干什么的。
    4. debug: 一般放于程序的某个关键点的地方,用于打印一个变量值或者一个方法返回的信息之类的信息     
    5.  trace:  一般不会使用,在日志里边也不会打印出来,最低的一个日志级别。

    2.Logback中的配置文件

    详细使用可以参考:https://www.cnblogs.com/warking/p/5710303.html

    Logback会依次读取以下类型配置文件

    • logback.groovy
    • logback-test.xml
    • logback.xml
    • 如果均不存在会使用默认配置

    2.1 组件之间关系

    1. Logger:日志记录器,关联到应用的对应的context上后,主要用于存放日志对象,可以定义日志的类型级别。
    2. Appender:用于指定日志输出的目的地,目的地可以是控制台,日志,数据库等。
    3. Layout:负责把事件转化成字符串格式化的日志输出,在Logback中Layout被封装在encoder中

    在resources目录下创建logback.xml,

    1.  
      <?xml version="1.0" encoding="utf-8" ?>
    2.  
      <configuration>
    3.  
      <property name = "ENCODER_PATTERN" value = "%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{80} - %msg%n"/>
    4.  
      <!-- 控制台日志:输出全部日志到控制台 -->
    5.  
      <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
    6.  
      <!-- 控制输出流对象,默认System.out 改为System.err-->
    7.  
      <target>System.err</target>
    8.  
      <!-- 日志消息格式配置-->
    9.  
      <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
    10.  
      <pattern>${ENCODER_PATTERN}</pattern>
    11.  
      </encoder>
    12.  
      </appender>
    13.  
      <!-- root Logger 配置-->
    14.  
      <root>
    15.  
      <appender-ref ref="console"></appender-ref>
    16.  
      </root>
    17.  
      </configuration>

    再次执行,输出结果变成如下:

    参考:

    https://www.cnblogs.com/renrenbinbin/archive/2012/12/25/2832525.html

    https://baike.baidu.com/item/logback/5822369

    https://www.cnblogs.com/rrong/p/9712623.html

  • 相关阅读:
    服务器资源共享--IIS站点/虚拟目录中访问共享目录(UNC)
    sql reiserror 输出错误
    使用xib方式创建UITableViewCell,设置Label自动换行注意事项
    原生的UITableViewCell高度自适应,textLabel自动换行显示
    屏幕截取-2种模式
    NSDictionary初始化,使用@{}方法,插入nil时会报空指针异常
    Unicode解码、URL编码/解码
    解决UITableView数据没有充满屏幕时,显示多余的空白cell的问题
    UITableView的分割线不满屏的解决方法
    动态获取UIWebView的真正高度
  • 原文地址:https://www.cnblogs.com/shoshana-kong/p/14321105.html
Copyright © 2011-2022 走看看