SpringBoot日志级别与日志分组详解
日志级别
1、级别内容
- 从低到高:
ALL、TRACE、DEBUG、INFO、WARN、ERROR、FATAL、OFF;ALL:打印 所有日志TRACE:追踪框架详细流程日志,一般不使用,记录运行到哪一步了DEBUG:开发调试的细节日志INFO:关键、感兴趣消息日志WARN:警告,但不是错误信息,如版本过时等。- 从 ERROR 开始包括 ERROR 再往上(从低到高)就是出现错误(导致程序运行不了)的日志了。
ERROR:业务错误日志FATAL:致命错误日志OFF:关闭 所有日志记录
- 只会打印指定级别及以上(从低到高)级别的日志,验证演示(打印
TRACE到ERROR,这是开发期间常用的4个日志类型)如下:- 要使用
log得先导入lombok.extern.slf4j.Slf4j,并在开头添加@Slf4j(直接添加@Slf4j会自动导入lombok.extern.slf4j.Slf4j)
- 要使用
编写如下代码:
package com.atwyb.logging.com.atwyb.logging.controller;
//package自己的cotroller包路径
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
@Slf4j
@RestController
public class HelloController {
@GetMapping("/h")
public String hello(){
log.trace("trace 日志");
log.debug("debug 日志");
log.info("info 日志");
log.warn("warn 日志");
log.error("error 日志");
return "hello";
}
}启动程序,访问/h后观察到控制台,发现只打印了INFO及以上的日志,因为SpringBoot 默认的日志级别为INFO,所以不打印TRACE、DEBUG

2、调整日志级别
调整默认日志级别
在SpringBoot中,可以精确调整某一个类的级别。
若不调整,所有类都会使用application.propertise中logging.level.root指定的日志级别,如图所示。

将logging.level.root调整为debug后,运行访问/h后,显示日志为debug,如下图。

调整指定类的日志级别
修改logging.level.*(*为所要修改的包名及路径)即可,修改为warn,如下图。

验证,运行项目观察控制台,发现指定包的日志只显示warn及以后的了,其它没调整的都是默认日志等级(前面修改为了debug)。

项目开发过程中,利用日志来测试的小技巧
在项目开发测试过程中,利用常用的log.info,对参数进行验证。
日志相比于直接在控制台输出,可以用以下格式
log.info("info 日志 参数A:{} 参数B:{}",A,B);修改前面的代码:
package com.atwyb.logging.com.atwyb.logging.controller;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
@Slf4j
@RestController
public class HelloController {
@GetMapping("/h")
public String hello(String A,String B){
log.trace("trace 日志");
log.debug("debug 日志");
log.info("info 日志 参数A:{} 参数B:{}",A,B);
log.warn("warn 日志");
log.error("error 日志");
return "hello";
}
}启动服务器后,访问http://localhost:8080/h?A=1&B=2,传输A、B参数值后,在控制台可以看得到info信息中带有A、B的值。

日志分组
在有多个包需要指定日志类型时,可以通过分组快速指定。
比如需要指定以下类都为debug
logging.level.com.a=debug logging.level.com.b=debug logging.level.com.c=debug logging.level.com.d=debug
可以用以下形式替代
logging.group.abc=com.a,com.b,com.c,com.d logging.level.abc=debug
SpringBoot 预定义了两个组:web、sql,在可以在application.propertise直接指定。
到此这篇关于SpringBoot日志级别与日志分组详解的文章就介绍到这了,更多相关SpringBoot日志级别与日志分组内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Spring Boot3整合OAuth2实现第三方登录功能详细示例
OAuth是一个关于授权的开放网络标准,在全世界得到广泛应用,目前的版本是2.0版,这篇文章主要介绍了Spring Boot3整合OAuth2实现第三方登录功能的相关资料,需要的朋友可以参考下2025-06-06
Java中BigInteger与BigDecimal类用法总结
在Java中有两个用于大数字运算的类,分别是java.math.BigInteger类 和 java.math.BigDecimal类,这两个类都可以用于高精度计算,BigInteger类是针对整型大数字的处理类,而BigDecimal类是针对大小数的处理类,接下来带大家来学习一下,在Java中如何处理大数字2023-05-05
Java存储过程调用@NamedStoredProcedureQuery示例详解
本文探讨了@NamedStoredProcedureQuery的基础知识、参数配置与映射、结果集处理、执行方法、批量定义与组织、异常和事务处理以及最佳实践与性能优化等方面,感兴趣的朋友一起看看吧2025-05-05


最新评论