文章目录
- 1、Lombok简介
- 2、SLF4J简介
- 3、实现步骤
- 3.1 创建SpringBoot项目
- 3.2 添加依赖
- 3.3 使用 @Slf4j 注解
- 3.4 输出日志信息
- 4、结论
在现代Java
开发中,日志记录是至关重要的。它不仅帮助开发者调试代码,还便于监控系统运行状态和性能。
Lombok
和 SLF4J
的结合提供了一种优雅的解决方案,可以极大地简化日志记录的过程。
1、Lombok简介
Lombok
是一个用于减少Java
代码中常见冗余的库。它通过注解来自动插入开发者通常需要手动编写的代码,如getter
、setter
、构造函数
等。对于日志记录,Lombok
提供了一个 @Slf4j
注解,可以自动创建一个 Logger 实例
。
2、SLF4J简介
SLF4J
(Simple Logging Facade for Java
)是一个日志框架的简单抽象层,允许最终用户在部署其应用时使用所希望的日志框架。SLF4J
的设计目标是简单和高效,它不提供任何具体的日志实现,而是作为一个接口存在,具体的实现可以是 Logback
、Log4j
或其他。
3、实现步骤
3.1 创建SpringBoot项目
创建一个SpringBoot
项目,选择Spring Web
3.2 添加依赖
pom.xml
文件中添加Lombok
依赖:
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.34</version>
</dependency>
3.3 使用 @Slf4j 注解
在类上使用 @Slf4j
注解,Lombok
将会自动创建一个名为 log
的静态 final Logger 对象
:
package com.log;
import lombok.extern.slf4j.Slf4j;
@Slf4j
public class MyLog {
}
3.4 输出日志信息
现在可以自由地在代码中使用 log
变量来输出不同级别的日志信息了:
public void testLog(){
log.trace("This is a trace message.");
log.debug("This is a debug message.");
log.info("This is a info message.");
log.warn("This is a warn message.");
log.error("This is a error message.");
}
运行后,控制台会看到信息:
怎么只有3条信息?前2条呢?因为默认的日志级别为info
,trace和debug级别
就没有显示出来。如果想更改日志级别,可以在application.yml
文件配置日志打印级别,比如改成trace
,如下:
logging:
level:
root: trace
重新启动服务,这次就会在日志中看到:
从控制台输出的结果可以初步分析出,trace
级别最低,可以打印所有级别的日志。
在整个日志体系中,级别从低到高分为:TRACE < DEBUG < INFO < WARN < ERROR
,
级别越底,可打印的日志就更多;相反,级别越高,输出的日志就更少。
从实际情况来看,太多的日志打印也未必是一件好事,有时候会把服务器磁盘撑爆,导致服务宕机。
通常我们会配置INFO级别
,在关键的位置打印相关信息即可。
4、结论
Lombok
和 SLF4J
的结合使用极大地简化了Java
中的日志记录过程。