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 "打印⽇志";
	}
}
相关推荐
devpotato6 小时前
Spring Boot mTLS 报 `keystore password was incorrect`:不一定是密码错了
spring boot·tls·pkcs12·mtls
keep one's resolveY7 小时前
SpringBoot实现重试机制的四种方案
java·spring boot·后端
阿丰资源9 小时前
基于Spring Boot的电影城管理系统(直接运行)
java·spring boot·后端
消失的旧时光-194310 小时前
Spring Boot 工程化进阶:统一返回 + 全局异常 + AOP 通用工具包
java·spring boot·后端·aop·自定义注解
StockTV11 小时前
印度股票实时数据 NSE和BSE的实时行情、K 线及指数数据
java·开发语言·spring boot·python
橘子海全栈攻城狮12 小时前
【最新源码】养老院系统管理A013
java·spring boot·后端·web安全·微信小程序
敖正炀12 小时前
反模式与排查宝典:Spring Boot 自动配置与核心机制的常见陷阱
spring boot
直奔標竿13 小时前
Java开发者AI转型第二十六课!Spring AI 个人知识库实战(五)——联网搜索增强实战
java·开发语言·人工智能·spring boot·后端·spring
快乐非自愿13 小时前
Redis--SDS字符串与集合的底层实现原理
数据库·redis·缓存