SpringBoot 下在 yml 中的 logging 日志配置方法

 更新时间:2024年06月26日 11:43:23   作者:杜小舟  
logging 配置主要用于控制应用程序的日志输出行为,可以通过配置定制日志的格式、级别、输出位置等,这篇文章主要介绍了SpringBoot 下在 yml 中的 logging 日志配置,需要的朋友可以参考下

前言

logging 配置主要用于控制应用程序的日志输出行为,可以通过配置定制日志的格式、级别、输出位置等。

输出日志的级别

控制哪些级别的日志会被记录,常见级别有:

  • ERROR:用于记录严重错误或异常,出现了这个日志,就说明程序中有严重的错误或者异常已经影响到了某些功能的运行。
  • WARN:输出出现问题的警告信息,但是这些问题还不影响系统的正常运行,主要是让开发者和运维人员注意这些可能引发问题的情况,以便在问题变得严重之前进行排查和处理。
  • INFO:用于记录普通的操作信息和运行状态。这些日志通常用于了解应用程序的正常运行情况。
  • DEBUG:用于记录详细的调试信息。这些日志通常包含比 INFO 级别更多的细节,适用于调试和开发阶段,帮助开发者了解系统的内部工作流程。DEBUG 日志通常包括方法的入口和出口、变量值、逻辑分支的走向等。
  • TRACE:这个级别用于记录最详细的调试信息。这些日志通常包含比 DEBUG 级别更细粒度的信息,适用于深度调试和分析问题。TRACE 日志详细到函数的每一步执行情况,参数传递和返回值等,非常适合在开发阶段或问题排查时使用。

当然,也可以针对不同的包或者类单独设置日志级别。

logging:
  level:
  	# 总级别
    root: INFO
    # 单个包的级别
    com.example: DEBUG

日志输出的位置

配置日志文件输出到的位置和名称。
如果想配置不同级别的日志输出的位置和名称,需要使用 Logback 配置文件。

logging:
  file:
    name: /var/log/my.log

日志输出的格式

配置日志的输出格式,可以通过设置不同的模式来定制日志的输出样式。

logging:
  pattern:
  	# 控制台输出格式
    console: "%d{yyyy-MM-dd HH:mm:ss} - %msg%n"
    # log文件输出格式
    file: "%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n"

日志文件的存储路径

指定日志文件的存储路径,可以指定一个目录,日志文件将存储在这个目录下。

logging:
  path: /var/log/mylog

日志文件是否输出到控制台配置

配置是否将日志输出到控制台。

logging:
  console:
    enabled: true

Logback 配置

Logback 是 Spring Boot 默认使用的日志框架,可以在 logging.logback 下进行更详细的配置,比如自定义 Logback 的配置文件。

logging:
  # 通过指定自定义的配置文件做更详细的配置
  config: classpath:logback-spring.xml

日志分组配置

可以为日志级别配置创建分组,方便统一管理。允许将一组包或类分配到一个日志级别组中,从而简化日志级别的配置管理。通过分组配置,可以一次性为多个包或类设置相同的日志级别,而不需要单独为每个包或类进行配置

logging:
  group:
    service: com.example.service, com.example.service.impl
    repository: com.example.repository, com.example.repository.impl
    controller: com.example.controller
  level:
    root: INFO
    service: DEBUG
    repository: ERROR
    controller: WARN
    com.example.controller.special: TRACE

日志细粒度配置【logger】

细粒度的日志配置,可以为特定的类或包单独配置日志级别。这在需要针对某些特定部分进行详细调试时非常有用。

logging:
  level:
    root: INFO
  # 细粒度日志配置
  logger:
    # 为 com.example.service 包下的所有类设置 DEBUG 级别
    com.example.service:
      level: DEBUG
      file: /var/log/myapp/service.log
    # 为 com.example.repository.DBRepository 类设置 TRACE 级别
    com.example.repository.DBRepository:
      level: TRACE
      file: /var/log/myapp/repository.log
    # 为 com.example.controller 包下的所有类设置 WARN 级别
    com.example.controller:
      level: WARN
    # 为 com.example.util 包下的所有类设置 ERROR 级别
    com.example.util:
      level: ERROR

到此这篇关于SpringBoot 下在 yml 中的 logging 日志配置的文章就介绍到这了,更多相关SpringBoot logging 日志配置内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • SpringBoot/Spring AOP默认动态代理方式实例详解

    SpringBoot/Spring AOP默认动态代理方式实例详解

    这篇文章主要给大家介绍了关于SpringBoot/Spring AOP默认动态代理方式的相关资料,Spring AOP是一款基于Java的AOP框架,其中默认采用动态代理方式实现AOP功能,本文将详细介绍动态代理的实现原理和使用方法,需要的朋友可以参考下
    2023-03-03
  • SpringBoot整合jnotify实现针对指定目录及其(动态)子目录的监听的方法

    SpringBoot整合jnotify实现针对指定目录及其(动态)子目录的监听的方法

    本文介绍了JNotify这一Java库在SpringBoot中的应用,JNotify允许应用程序监听文件系统事件,包括文件夹/文件的创建、删除、修改和重命名,由于JNotify底层调用的关键部分是C语言开发的,所以在使用前需要在系统中加入相应的动态库
    2024-10-10
  • Mybatis源码解析之事务管理

    Mybatis源码解析之事务管理

    大家好,本篇文章主要讲的是Mybatis源码解析之事务管理,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览
    2021-12-12
  • 史上最全面的Spring Boot配置文件深入讲解

    史上最全面的Spring Boot配置文件深入讲解

    Springboot极大的简化了Spring框架的使用配置流程,在核心配置文件里,几乎可以完成所有的配置工作,下面这篇文章主要给大家介绍了关于Spring Boot配置文件的相关资料,文中介绍的非常全面,需要的朋友可以参考下
    2018-12-12
  • 如何通过Java实现加密、解密Word文档

    如何通过Java实现加密、解密Word文档

    这篇文章主要介绍了如何通过Java实现加密、解密Word文档,对一些重要文档,常需要对文件进行加密,查看文件时,需要正确输入密码才能打开文件。下面介绍了一种比较简单的方法给Word文件加密以及如何给已加密的Word文件解除密码保护,需要的朋友可以参考下
    2019-07-07
  • Java实现对象列表导出为excel表格的实用工具类

    Java实现对象列表导出为excel表格的实用工具类

    这篇文章主要为大家详细介绍了Java如何实现对象列表导出为excel表格的实用工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-12-12
  • Dwr3.0纯注解(纯Java Code配置)配置与应用浅析二之前端调用后端

    Dwr3.0纯注解(纯Java Code配置)配置与应用浅析二之前端调用后端

    我们讲到了后端纯Java Code的Dwr3配置,完全去掉了dwr.xml配置文件,但是对于使用注解的类却没有使用包扫描,而是在Servlet初始化参数的classes里面加入了我们的Service组件的声明暴露,对于这个问题需要后面我们再细细研究下这篇文章,主要分析介绍前端怎么直接调用后端
    2016-04-04
  • java实现门禁系统

    java实现门禁系统

    这篇文章主要为大家详细介绍了java实现门禁系统的实现方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-01-01
  • SpringBoot热部署配置方法详解

    SpringBoot热部署配置方法详解

    在实际开发中,每次修改代码就需要重启项目,重新部署,对于一个后端开发者来说,重启确实很难受。在java开发领域,热部署一直是一个难以解决的问题,目前java虚拟机只能实现方法体的热部署,对于整个类的结构修改,仍然需要重启项目
    2022-11-11
  • 剖析Java中在Collection集合中使用contains和remove为什么要重写equals

    剖析Java中在Collection集合中使用contains和remove为什么要重写equals

    这篇文章主要介绍了Collection集合的contains和remove方法详解remove以及相关的经验技巧,通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-09-09

最新评论