在 SpringBoot 项目开发及线上运行中免不了使用日志,日志可以帮忙我们在开发和解决线上BUG时去定位问题,这篇文章主要带大家了解一下 SpringBoot 中日志如何使用及线上日志该怎么配置。
接触过日志的同学比较困扰的是,日志好像很多种,Apache Commons Logging、Slf4j、Log4j、Log4j2、Logback等等,完全搞不懂应该用哪个以及怎么用。
其实我们可以把日志分为我们熟悉的接口和实现类。
- 日志接口: Apache Commons Logging、Slf4j
主要是定义日志的接口规范,并不提供日志底层的具体实现逻辑,类似于我们定义的service接口。
- 日志实现: Log4j、Log4j2、Logback
这些则是日志的具体实现,包括实现了日志级别的控制、日志打印格式、日志输出形式(输出到数据库、输出到文件、输出到控制台等),类似于我们的service实现类。
为什么要把日志定义接口和实现类?
其实是方便我们在相同日志接口下的不同日志框架实现自由切换,不需要改动任何代码。
一、SpringBoot 种日志使用
- 依赖引入
如果已经引入了spring-boot-starter或spring-boot-starter-web则不需要再引入,已经包含其中。
xml复制代码<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</dependency>
SpringBoot默认使用的日志框架是Logback,也是目前最常使用的日志框架,如果想使用其他日志框架需要单独引入依赖并写相应的配置,这里我们就直接使用默认的Logback。
- 打印日志
java复制代码import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class LoggerController {
// 1. 得到日志对象
private Logger logger = LoggerFactory.getLogger(LoggerController.class);
@RequestMapping("/logger")
public String logger() {
// 2. 日志打印
logger.trace("日志级别: trace");
logger.debug("日志级别: debug");
logger.info("日志级别: info");
logger.warn("日志级别: warn");
logger.error("日志级别: error");
return "logger&#