SpringBoot日志级别与日志分组详解

 更新时间:2025年08月29日 14:24:55   作者:天天开心a  
文章介绍了日志级别(ALL至OFF)及其作用,说明SpringBoot默认日志级别为INFO,可通过application.properties调整全局或特定类的日志级别,并展示了日志调试技巧和分组配置方法,感兴趣的朋友跟随小编一起看看吧

日志级别

1、级别内容

  • 从低到高:ALL、TRACE、DEBUG、INFO、WARN、ERROR、FATAL、OFF
    • ALL打印 所有日志
    • TRACE:追踪框架详细流程日志,一般不使用,记录运行到哪一步了
    • DEBUG:开发调试的细节日志
    • INFO:关键、感兴趣消息日志
    • WARN:警告,但不是错误信息,如版本过时等。
    • 从 ERROR 开始包括 ERROR 再往上(从低到高)就是出现错误(导致程序运行不了)的日志了。
    • ERROR:业务错误日志
    • FATAL:致命错误日志
    • OFF关闭 所有日志记录
  • 只会打印指定级别及以上(从低到高)级别的日志,验证演示(打印TRACEERROR,这是开发期间常用的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.propertiselogging.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日志级别与日志分组内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • java HashMap的keyset实例

    java HashMap的keyset实例

    简单地说,在keyset方法返回的set上做修改会改变原来hashmap,这也许不是你想要的,于是形成一个隐藏的bug
    2013-04-04
  • Spring Boot3整合OAuth2实现第三方登录功能详细示例

    Spring Boot3整合OAuth2实现第三方登录功能详细示例

    OAuth是一个关于授权的开放网络标准,在全世界得到广泛应用,目前的版本是2.0版,这篇文章主要介绍了Spring Boot3整合OAuth2实现第三方登录功能的相关资料,需要的朋友可以参考下
    2025-06-06
  • Java实现线程按序交替执行的方法详解

    Java实现线程按序交替执行的方法详解

    这篇文章主要为大家详细介绍了Java如何实现线程按序交替执行,文中的示例代码讲解详细,对我们了解线程有一定帮助,需要的可以参考一下
    2022-10-10
  • Java控制台实现猜拳游戏小游戏

    Java控制台实现猜拳游戏小游戏

    这篇文章主要为大家详细介绍了Java控制台实现猜拳游戏小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-11-11
  • Java中BigInteger与BigDecimal类用法总结

    Java中BigInteger与BigDecimal类用法总结

    在Java中有两个用于大数字运算的类,分别是java.math.BigInteger类 和 java.math.BigDecimal类,这两个类都可以用于高精度计算,BigInteger类是针对整型大数字的处理类,而BigDecimal类是针对大小数的处理类,接下来带大家来学习一下,在Java中如何处理大数字
    2023-05-05
  • @RequestMapping对不同参数的接收方式示例详解

    @RequestMapping对不同参数的接收方式示例详解

    Spring MVC框架中,@RequestMapping注解用于映射URL到控制器方法,不同的参数类型如简单参数、实体参数、数组参数、集合参数、日期参数和JSON参数,本文给大家介绍@RequestMapping对不同参数的接收方式,感兴趣的朋友一起看看吧
    2024-10-10
  • 浅谈spring.factories文件的作用

    浅谈spring.factories文件的作用

    本文主要介绍了浅谈spring.factories文件的作用,spring.factories文件是Spring Boot自动配置的核心文件之一,它的作用是将各种自动配置类与对应的配置类集中在一起,下面就来介绍一下如何使用,感兴趣的可以了解一下
    2024-06-06
  • 浅谈Java线程并发知识点

    浅谈Java线程并发知识点

    本文主要对Java线程并发的知识点进行简单介绍。具有很好的参考价值,需要的朋友一起来看下吧
    2016-12-12
  • 详解springcloud Feign的Hystrix支持

    详解springcloud Feign的Hystrix支持

    这篇文章主要介绍了详解springcloud Feign的Hystrix支持,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-01-01
  • Java存储过程调用@NamedStoredProcedureQuery示例详解

    Java存储过程调用@NamedStoredProcedureQuery示例详解

    本文探讨了@NamedStoredProcedureQuery的基础知识、参数配置与映射、结果集处理、执行方法、批量定义与组织、异常和事务处理以及最佳实践与性能优化等方面,感兴趣的朋友一起看看吧
    2025-05-05

最新评论