springboot日志集成Logback

it2026-04-04  4

springboot日志集成Logback

一、Logback二、编辑controller三、日志级别的控制四、日志文件


java有许多的日志组件,比如 log4j,log4j2,logback还有java自生提供的Java Util Logging,其实在springboot中对这些组件都提供了支持,log4j,log4j2和logback都提供相应的组件支持。

一、Logback

在springboot中默认使用的日志工具是logback,不过在提及具体的日志工具之前要提一个名词,这个名词就是slf4j简单日志门面(Simple Logging Facade For Java)

百度百科解释https://baike.baidu.com/item/slf4j/6408868

slf4j不是具体的日志解决方案,它有点类似于jdbc,使用了门面模式,是一个针对各类日志的抽象实现,既然是抽象的日志实现,在springboot中肯定不需要额外导入。

注意:spring-boot-starter中就提供了对spring-boot-starter-logging的依赖在spring-boot-starter-logging中可以看到以及集成了slf4j与具体实现logback的默认支持

二、编辑controller

import org.slf4j.Logger; import org.slf4j.LoggerFactory; private final Logger logger=LoggerFactory.getLogger(UserController.class);

在浏览器上输入:localhost:8080/hello,可以看控制台日志的输出

三、日志级别的控制

默认情况下,Spring Boot 配置的是INFO 日志级别,也就是会输出INFO级别以上的日志(ERROR, WARN, INFO)。

如果需要 Debug 级别的日志。在src/main/resources/application.properties 中配置debug=true配置 logging.level.* 来具体输出哪些包的日志级别。 例如: logging.level.root=INFO #除了以下的包是debug,其他所有文件都是info级别 logging.level.org.springframework.web=DEBUG logging.level.cn.enjoy.controller=DEBUG

四、日志文件

一般情况下,springboot日志只会输出到控制台,并不会写入到日志文件,但是,在一些正式环境的应用中,我们需要通过在 application.properites 文件中配置 logging.file 文件名称和 logging.path 文件路径,将日志输出到日志文件中。

logging.path = /var/tmp logging.file = xxx.log logging.level.root = info

注意: 如果只配置 logging.path,在 /var/tmp文件夹生成一个日志文件为 spring.log。如果只配置 logging.file,会在项目的当前路径下生成一个 xxx.log 日志文件。

这里有一个坑,logging.path 和logging.file都配置了,只会有logging.file生效,所以,如果要指定日志生成的具体位置使用logging.file 配置就好

在application.properties中配置logging.file =F:\log\enjoy.log

这样在F盘的相应位置出现日志文件

最新回复(0)