Spring Boot支持log4j、logback作为日志框架。
如果你使用starters启动器,Spring Boot将使用Logback作为默认日志框架。
spring-boot-starter启动器包含spring-boot-starter-logging启动器并集成了slf4j日志抽象及Logback日志框架。
1.slf4j(Simple logging Facade for Java)
它是把不同的日志系统的实现进行了具体的抽象化,只提供了统一的日志使用接口,使用时只需要按照其提供的接口方法进行调用即可,由于它只是一个接口,并不是一个具体的可以直接单独使用的日志框架,所以最终日志的格式、记录级别、输出方式等都要通过接口绑定的具体的日志系统来实现,这些具体的日志系统就有log4j、logback等,它们才实现了具体的日志系统的功能。
既然SLF4J只是一个接口,那么实际使用时必须要结合具体的日志系统来使用,我们首先来看SLF4J和各个具体的日志系统进行绑定时的框架原理图:
其实slf4j原理很简单,他只提供一个核心slf4j api(就是slf4j-api.jar包),这个包只有日志的接口,并没有实现,所以如果要使用就得再给它提供一个实现了些接口的日志包,比如:log4j、common logging、jdk log日志实现包等,但是这些日志实现又不能通过接口直接调用,实现上他们根本就和slf4j-api不一致,因此slf4j又增加了一层来转换各日志实现包的使用,当然slf4j-simple除外。其结构如下:
slf4j-api(接口层)
|
各日志实现包的连接层( slf4j-jdk14, slf4j-log4j)
|
各日志实现包
所以,结合各日志实现包使用时提供的jar包情况为:
SLF4J和logback结合使用时需要提供的jar: slf4j-api.jar、logback-classic.jar、logback-core.jar
SLF4J和log4j结合使用时需要提供的jar: slf4j-api.jar、slf4j-log412.jar、log4j.jar
SLF4J和JDK中java.util.logging结合使用时需要提供的jar: slf4j-api.jar、slf4j-jdk14.jar
SLF4J和simple(SLF4J本身提供的一个接口的简单实现)结合使用时需要提供的jar: slf4j-api.jar、slf4j-simple.jar
当然还有其他的日志实现包,以上是经常会使用到的一些。
注意,以上slf4j和各日志实现包结合使用时最好只使用一种结合,不然的话会提示重复绑定日志,并且会导致日志无法输出。
slf4j-api.jar:对外提供统一的日志调用接口,该接口具体提供的调用方式和方法举例说明:
public class Test {
private static final Logger logger = LoggerFactory.getLogger(Tester.class); //通过LoggerFactory获取Logger实例
public static void main(String[] args) {
//接口里的统一的调用方法,各具体的日志系统都有实现这些方法
logger.info("testlog: {}", "test");
logger.debug("testlog: {}", "test");
logger.error("testlog: {}", "test");
logger.trace("testlog: {}", "test");
logger.warn("testlog: {}", "test");
}
}
如果系统中之前已经使用了log4j做日志输出,想使用slf4j作为统一的日志输出,该怎么办呢?
如果之前系统中是单独使用log4j做为日志输出的,这时再想使用slf4j做为日志输出时,如果系统中日志比较多,此时更改日志输出方法肯定是不太现实的,这个时候就可以使用log4j-over-slf4j.jar将使用log4j日志框架输出的日志路由到slf4j上来统一采用slf4j来输出日志。
为什么要使用SLF4J?
2.log4j(log for java)
Log4j是Apache的一个开源项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件,甚至是套接口服务器、NT的事件记录器、UNIX Syslog守护进程等;我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程。最令人感兴趣的就是,这些可以通过一个配置文件来灵活地进行配置,而不需要修改应用的代码。
如何使用?
private static final Logger logger = Logger.getLogger(Tester.class); //通过Logger获取Logger实例
logger.debug(“System …..”)
3.logback
logback同样是由log4j的作者设计完成的,拥有更好的特性,用来取代log4j的一个日志框架,是slf4j的原生实现(即直接实现了slf4j的接口,而log4j并没有直接实现,所以就需要一个适配器slf4j-log4j12.jar)。logback一共有以下几个模块:
同样,单独使用它时,需要引入以上jar,然后进行配置文件的配置,最后就是在相关类中进行使用,使用时加入以下语句:
private final static Logger logger = LoggerFactory.getLogger(Test.class);
logger.info("打印日志");