Spring Boot日志

文章目录


打印日志

 在程序中获取日志对象需要使⽤⽇志⼯厂 LoggerFactory,获取对象后可以先使⽤ info() ⽅法来输出日志。

java 复制代码
@RestController
public class LoggerController {
	private static Logger logger = LoggerFactory.getLogger(LoggerController.class);
	
	@RequestMapping("/logger")
	public String logger(){
		logger.info("--------------要输出⽇志的内容----------------");
		return "打印⽇志";
	}
}

日志框架

 打印日志时使用的Logger 对象是属于 org.slf4j 包下的

 SLF4J是门面模式的典型应用,在 Java 生态系统中,存在多种日志框架(如 Log4j、JUL、Logback 等),它们各有优缺点。SLF4J 的主要作用就是提供统一的日志 API,并不涉及到具体的日志逻辑实现,从而避免日志框架之间的冲突。可以理解为小爱同学,通过小爱同学可以控制整个屋子的灯开关,但其本质并不实现灯的开关,而是由每个灯内部实现的。


图片来源

日志格式

 日志的输出包含以下内容

  • 时间:精确到毫秒
  • 日志级别:ERROR, WARN, INFO, DEBUG 或TRACE
  • 进程ID:例子中是22000
  • 线程名:例子中是main
  • Logger名(通常使⽤源代码的类名)
  • 日志内容

日志级别

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

  • FATAL: 致命信息,表示需要立即被处理的系统级错误.
  • ERROR: 错误信息, 级别较⾼的错误⽇志信息, 但仍然不影响系统的继续运行
  • WARN: 警告信息, 不影响使⽤, 但需要注意的问题
  • INFO: 普通信息, ⽤于记录应⽤程序正常运行时的⼀些信息, 例如系统启动完成、请求处理完成等
  • DEBUG: 调试信息, 需要调试时候的关键信息打印
  • TRACE: 追踪信息, 比DEBUG更细粒度的信息事件(除非有特殊用意,否则请使用DEBUG级别替代)

 日志级别是开发⼈员自己设置的. 开发⼈员根据自己的理解来判断该信息的重要程度,SpringBoot 默认的日志框架是Logback, Logback没有 FATAL 级别,它被映射到 ERROR,当出现 FATAL 级别时,需要系统管理员紧急介⼊处理。

java 复制代码
@RequestMapping("/printLog")
public String printLog() {
	logger.trace("trace级别的日志");
	logger.debug("debug级别的日志");
	logger.info("info级别的日志");
	logger.warn("warn级别的日志");
	logger.error("error级别的日志");

return "打印不同级别的⽇志" ;
}

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

日志配置

日志级别配置

 日志级别配置只需要在配置文件中设置 " logging.level " 配置项即可

xml 复制代码
logging:
  level:
    root: debug

 此时设置默认的输出级别为 debug ,上面的代码会输出debug、info、warn 和 error级别的日志。

日志持久化

 日志持久化有两种方式

  • 配置日志文件名 logging.file.name
  • 配置日志的存储目录 logging.file.path

 如下所示,日志相关的信息会存放到 logger/文件夹下

xml 复制代码
logging:
  file:
    path: logger/

 配置name时,会给存放日志信息的文件进行命名

xml 复制代码
logging:
  file:
    name: logger/springboot.log

当二者同时配置时,以name的配置为准

日志分割配置

 如果日志都放在⼀个文件中, 随着项⽬的运行,日志文件会越来越⼤, 需要对日志文件进行分割,配置项如下所示,

  • logging.logback.rollingpolicy.file-name-pattern 表示日志分割后的文件名格式,默认值为${LOG_FILE}.%d{yyyy-MM-dd}.%i.gz
  • logging.logback.rollingpolicy.max-file-size 表示日志文件超过这个大小就自动分割,默认值为10MB
xml 复制代码
logging:
  logback:
    rollingpolicy:
      max-file-size: 1KB
      file-name-pattern: ${LOG_FILE}.%d{yyyy-MM-dd}.%i

日志格式配置

 打印日志的格式,也是支持配置的,支持控制台和日志文件分别设置,配置项如下,

  • logging.pattern.console 表示控制台日志格式
  • logging.pattern.file 表示日志文件的日志格式

通过lombox进行日志输出

通过添加 lombox,使用 @slf4j 注解输出日志,使用后会帮我们提供⼀个日志对象 log 进行输出

java 复制代码
@Slf4j
@RestController
public class LoggerController {

	@RequestMapping("/logger")
	public String logger(){
		log.info("--------------要输出⽇志的内容----------------");
		return "打印⽇志";
	}
}
相关推荐
一 乐11 分钟前
幼儿园管理系统|基于springboot + vue幼儿园管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·幼儿园管理系统
布朗克16832 分钟前
38 Spring Boot入门——自动配置、核心注解与Starter机制
java·spring boot·后端
半夜燃烧的香烟43 分钟前
springboot3.0 集成minio上传文件,支持多个桶名
java·开发语言·spring boot
m0_547722921 小时前
从零搭建乒乓球比赛管理系统——Spring Boot + 原生 HTML 实战
spring boot·后端·html
小马爱打代码1 小时前
Spring Boot 自动装配流程
java·spring boot·后端
我登哥MVP1 小时前
SpringCloud 核心组件解析:分布式配置管理
java·spring boot·分布式·spring·spring cloud·java-ee·maven
Flittly1 小时前
【AgentScope Java新手村系列】(6)Hook与Middleware
java·spring boot·笔记·spring·ai
i220818 Faiz Ul2 小时前
药店管理|基于springboot + vue药店管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·美食分享系统
IT策士2 小时前
Redis 从入门到精通:缓存经典难题 —— 穿透、击穿、雪崩
数据库·redis·缓存