Spring Boot 2.x中怎么使用日志框架

Spring Boot 2.x中怎么使用日志框架,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

为什么是SLF4J?

默认情况下,Spring Boot会用SLF4J + Logback来记录日志,并用INFO级别输出到控制台。

SLF4J,即简单日志门面(Simple Logging Facade for Java),它可以看做是一个接口框架,并不提供具体的实现,具体的实现由类似于Log4jLog4j2Logback等等这样的日志框架去完成。

我们为什么要在实际的应用中去使用SLF4J的API呢?
在阿里巴巴的开发手册上也给我们明确【强制】规定了

Spring Boot 2.x中怎么使用日志框架

而百度百科上也给出了相应的解释:

Spring Boot 2.x中怎么使用日志框架

SLF4J让你的代码独立于任何特定的日志记录API,可以让我们的程序更加的健壮,不会让你因为不同日志的实现而导致的问题去分心。

使用SLF4J的另外一个理由就是,它可以支持占位符

String name = "Vi";
logger.debug("My Name is {}", name);

这段程序在运行时刻才会拿到name这不仅缩减了代码中的许多字符串连接,而且减少了创建String对象所需要的堆内存资源

怎么使用SLF4J?

如果我们在一个Spring Boot 的程序中去使用SLF4J,我们不需要去引入其他的包,因为我们引入的有关spring-boot-starter中就已经包含了有关slf4j的jar包。我们只需要通过LoggerFactory去获取即可:

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

这里需要注意看我们选择的是不是slf4j包下的Logger,不要选错了哟。

配合Lombok使用@Slf4j

首先在pom.xml中添加Lombok的依赖:

        <dependency>
           <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>

然后打开IDEA的设置项,在Plugins中查找:

Spring Boot 2.x中怎么使用日志框架

Spring Boot 2.x中怎么使用日志框架

注意安装插件后记得重启使其生效!

然后,我们在项目中就可以这样去使用:

@Slf4j
public class Slf4JTest {
    public static void main(String[] args) {
        log.info("This is a Slf4jTest");
    }
}

关于Spring Boot 2.x中怎么使用日志框架问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注行业资讯频道了解更多相关知识。