一、日志框架简介java
对于一个应用程序来讲,日志的记录是必不可少的一部分。线上的问题追踪,基于日志业务逻辑统计分析等都离不开日志。java领域存在许多已经写好成熟的日志框架,常常使用的有JCL(jakarta Commons logging), SLF4J(simple Logging facade java), jboss-logging, log4j, JUL(java.util.logging), log4j2, logback等。spring
从实现来讲,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和logbackspringboot
二、日志框架之间的关系框架
由于日志框架之间没用造成统一的接口,所咱们在选日志门面和日志实现的时候不能选错。而日志抽象接口也基本分为两大阵营了,一个是JCL(jakarta Commons logging),另外一个是SLF4J。ide
Commons Logging和Slf4j是日志门面(门面模式是软件工程中经常使用的一种软件设计模式,也被称为正面模式、外观模式。它为子系统中的一组接口提供一个统一的高层接口,使得子系统更容易使用)。log4j和Logback则是具体的日志实现方案。能够简单的理解为接口与接口的实现,调用这只须要关注接口而无需关注具体的实现,作到解耦。spa
其中比较经常使用的组合使用方式是Slf4j与Logback组合使用(SpringBoot),Commons Logging与Log4j组合使用(Spring)。debug
Logback必须配合Slf4j使用。因为Logback和Slf4j是同一个做者,其兼容性不言而喻。设计
三、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"); } }
加入咱们想在springBoot使用其余框架实现呢,要怎么办?以下图
好比咱们先在SpringBoot中使用log4j框架日志,不单单要导入log4j.jar包,还要导入slf4j-log412.jar包,该jar包是一个是适配器,将slf4抽象接口和log4j进行适配。每个日志的实现框架都有本身的配置文件,使用slf4j之后,配置文件仍是作成日志实现框架的配置文件。
四、日志级别
日志级别由低到高:trace<debug<info<warn<error,日志会输出大于等于当前所设置的日志级别,好比我设置日志级别为info,则就输出info、warn、和error级别的日志信息,trace和debug将被忽视。咱们还能够设置把日志写到文件中,好比配置 logging.file=d:/springboot.log,则会在d盘上生成springboot.log文件。logging.path配置的是制定日志文件生成在哪一个文件夹。