springboot-日志框架

旧街凉风 提交于 2020-01-01 03:14:27

1、日志框架简介

  对于一个应用程序来说,日志的记录是必不可少的一部分。线上的问题追踪,基于日志业务逻辑统计分析等都离不开日志。java领域存在许多已经写好成熟的日志框架,经常使用的有JCL(jakarta Commons logging), SLF4J(simple Logging facade java), jboss-logging, log4j, JUL(java.util.logging), log4j2, logback等。

  从实现来说,java框架分为两种,一种是日志门面(日志的抽象层)和日志实现,所以我们在选日志框架的时候,一般都是选一个日志门面,然后再选一个日志实现。其中,日志门面包括JCL(jakarta Commons logging), SLF4J(simple Logging facade java), jboss-logging等,而日志实现则包括 log4j, JUL(java.util.logging), log4j2, logback。

  Spring框架默认使用的就是JCL, 实现层可以选log4j或者log4j2,而Spring boot选用的是 SLF4J和logback

2、日志框架之间的关系

  因为日志框架之间没用形成统一的接口,所我们在选日志门面和日志实现的时候不能选错。而日志抽象接口也基本分为两大阵营了,一个是JCL(jakarta Commons logging),另一个是SLF4J。

  Commons Logging和Slf4j是日志门面(门面模式是软件工程中常用的一种软件设计模式,也被称为正面模式、外观模式。它为子系统中的一组接口提供一个统一的高层接口,使得子系统更容易使用)。log4j和Logback则是具体的日志实现方案。可以简单的理解为接口与接口的实现,调用这只需要关注接口而无需关注具体的实现,做到解耦。

  其中比较常用的组合使用方式是Slf4j与Logback组合使用(SpringBoot),Commons Logging与Log4j组合使用(Spring)。

  Logback必须配合Slf4j使用。由于Logback和Slf4j是同一个作者,其兼容性不言而喻。

3、SLF4J使用

  开发的时候,日志记录方法的调用,不应该来直接调用日志的实现类,而是调用日志抽象层里面的方法,给系统导入slf4j和logback的实现jar包

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class HelloWorld {
  public static void main(String[] args) {
    Logger logger = LoggerFactory.getLogger(HelloWorld.class);
    logger.info("Hello World");
  }
}
View Code

  加入我们想在springBoot使用其他框架实现呢,要怎么办?如下图

  

  比如我们先在SpringBoot中使用log4j框架日志,不仅仅要导入log4j.jar包,还要导入slf4j-log412.jar包,该jar包是一个是适配器,将slf4抽象接口和log4j进行适配。每一个日志的实现框架都有自己的配置文件,使用slf4j以后,配置文件还是做成日志实现框架的配置文件。

 

4、日志级别

  日志级别由低到高:trace<debug<info<warn<error,日志会输出大于等于当前所设置的日志级别,比如我设置日志级别为info,则就输出info、warn、和error级别的日志信息,trace和debug将被忽视。我们还可以设置把日志写到文件中,比如配置  logging.file=d:/springboot.log,则会在d盘上生成springboot.log文件。logging.path配置的是制定日志文件生成在哪个文件夹。

 

    

 

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!