个人主页:♡喜欢做梦
欢迎 👍点赞 ➕关注 ❤️收藏 💬评论
目录
🍉日志的定义
🍉日志的使用
🍉日志的级别分类
🍑日志级别的使用
🍑日志级别的配置
🍉日志持久化
🍑什么是日志持久化?
🍑日志持久化的配置
🍉配置日志文件的文件
🍉更简单的日志输出
🍑添加依赖
🍑@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调用。