Spring Boot 日志实战:级别、持久化与 SLF4J 配置全指南

Spring Boot 日志实战:级别、持久化与 SLF4J 配置全指南

个人主页:♡喜欢做梦

欢迎  👍点赞  ➕关注  ❤️收藏  💬评论


目录

🍉日志的定义

🍉日志的使用

🍉日志的级别分类

🍑日志级别的使用

🍑日志级别的配置

🍉日志持久化

🍑什么是日志持久化?

🍑日志持久化的配置

🍉配置日志文件的文件

🍉更简单的日志输出

🍑添加依赖

🍑@Slf4j


🍉日志的定义

日志本质上是系统、软件或设备按时间顺序记录操作、事件或状态的文件文本,用于最终历史、排查问题和审计。

Spring Boot项目在启动时就有默认的日志输出:

核心作用

  • 问题排查:当软件崩溃、系统出错、时,日志会记录错误代码、发生时间和上下文,帮助技术人员定位原因。
  • 行为审计:记录用户的关键操作,比如谁登录了系统、谁修改了文件,用于追溯责任或合规检查。
  • 状态监控:实是记录系统资源使用情况,如CPU占用率、内存使用量、帮助发现性能瓶颈。

🍉日志的使用

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class LoggerController {
    private final static Logger logger= LoggerFactory.getLogger(LoggerController.class);
}

🍉日志的级别分类

日志的级别从高到低依次为:FATAL、ERROR、WARN、INFO、DEBUG、TRACE

  • FATAL:致命信息,表示需要立即被处理的系统级错误。
  • ERROR:错误信息,级别较高的错误日志信息,但不影响系统的继续运行。
  • WARN:警告信息,不影响使用,但需要注意。
  • INFO:普通信息,用于记录应用程序正常运行时的一些信息。
  • DRBUG:调试信息,需要调试时候的关键信息打印。
  • TRACE:追踪信息,比DEBUG更细粒的信息事件

🍑日志级别的使用

Spring Boot默认的日志框架是Logback,Logback没有FATAL级别,他被映射到ERROR。

@RestController
@RequestMapping("/logger")
public class LoggerController {
    private final static Logger logger= LoggerFactory.getLogger(LoggerController.class);
    @RequestMapping("/printlog")
    public String logger(){
        logger.error("error....");
        logger.warn("warn....");
        logger.info("info...");
        logger.debug("debug...");
        logger.trace("trace...");
        return "打印日志级别";
    }
}

打印结果:

这里的打印结果,只打印了error,warn,info是因为,这与日志级别的配置有关,日志的输出级别默认是info,所以只会打印大于等于info的级别,也就是info,warn,error。

🍑日志级别的配置

yml配置

logging:
  level:
    root: debug

properties

logging.level.root=debug

🍉日志持久化

🍑什么是日志持久化?

日志持久化是指将程序运行过程中产生的日志数据,从内存写入到磁盘等持久化存储介质的过程,核心目的是防止日志因系统崩溃、断电等意外丢失。

🍑日志持久化的配置

yml

logging:
  file:
    name: logger/l og.log

properities

logging.file.name=logger/log.log
  • 后面可可以跟绝对路径也可以是相对路径;

运行结果如下,日志保存在了对应的目录内容

🍉配置日志文件的文件

yml

  logback:
    rollingpolicy:
      max-file-size: 1KB
      file-name-pattern: ${LOG_FILE}.%d{yyyy-MM-dd}.%i

properities

logging.logback.rollingpolicy.file-name-pattern=${LOG_FILE}.%d{yyyy-MM-dd}.%i
logging.logback.rollingpolicy.max-file-size=1KB

🍉更简单的日志输出

🍑添加依赖

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

🍑@Slf4j

使用

@Slf4j
public class LoggerController2 {
    public String logger(){
        log.info("info....");
        return "打印日志";
    }
}

我们使用@Slf4j就不用写那一长句就可以直接调用日志,但是要使用log调用。

转载请说明出处内容投诉
CSS教程网 » Spring Boot 日志实战:级别、持久化与 SLF4J 配置全指南

发表评论

欢迎 访客 发表评论

一个令你着迷的主题!

查看演示 官网购买