Spring Boot集成/输出/日志级别控制/持久化开发实践

2025-08-01 20:50

本文主要是介绍Spring Boot集成/输出/日志级别控制/持久化开发实践,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过...

一、日志概述

1.1、Spring Boot日志简介

Spring Boot 作为Java生态中广泛使用的框架,提供了强大的日志功能,帮助开发者高效记录和追踪应用运行状态。日志系统在调试、监控和问题排查中扮演着关键角色,而 Spring Boot 默认集成了流行的日志框架(如Logback、Log4j2),并支持灵活的配置方式

1.2、日志框架与默认配置

Spring Boot默认采用 Logback 作为日志实现,通过 pring-boot-starter-logging 依赖自动引入。开发者无需额外配置即可使用基础的日志功能,如控制台输出和文件记录。日志级别(如INFO、DEBUG、ERROR)可通过配置文件(application.properties或application.yml)动态调整

1.3、日志的核心作用

  • 问题诊断:通过日志快速定位异常或性能瓶颈
  • 行为追踪:记录关键业务流程,便于审计和分析
  • 性能监控:结合日志聚合工具(如ELK、Graylog)实现实时监控

二、日志的使用

Spring Boot项目在启动时默认有日志输出

Spring Boot集成/输出/日志级别控制/持久化开发实践

显而易见,日志输出的内容与我们使用 System.out.println() 输出的格式不一样,我们输出的内容相比日志缺少了很多内容

Spring Boot集成/输出/日志级别控制/持久化开发实践

2.1、打印日志

2.1.1、获取日志对象

程序中获取日志对象需要使用日志工厂 LoggerFactory,代码如下:

@Controller
public class LoggerController {
    private Logger logger= LoggerFactory.getLogger(LoggerController.class);
}

LoggerFactory.getLogger() 方法需要传入一个参数来标识日志名称,这样可以明确日志来源的类名,便于在出现错误时快速定位问题

Spring Boot集成/输出/日志级别控制/持久化开发实践

2.1.2、使用日志对象打印日志

下面我们使用 info() 方法来输出日志:

@Controller
public class LoggerController {
    private androidLogger  logger = LoggerFactory.getLogger(LoggerController.class);
    @PostConstruct
    public void loggerTest(){
        logger.info("凡王之血,必以剑终");
    }
}

日志输出效果:

Spring Boot集成/输出/日志级别控制/持久化开发实践

2.2、日志格式的说明

Spring Boot集成/输出/日志级别控制/持久化开发实践

日志输出包含以下关键元素:

  1. 时间戳(精确到毫秒级)
  2. 日志级别(ERROR /WARN / INFO / DEBUG / TRACE)
  3. 进程ID
  4. 应用名称
  5. 线程名称
  6. Logger名称(通常对应源代码的类名)
  7. 日志正文内容

2.3、日志级别

我们在编写代码测试时,难免会出现错误,当出现错误时,我们观察日志信息:

Spring Boot集成/输出/日志级别控制/持久化开发实践

发现控制台有不同的日志级别,那么日志级别是用来干什么的呢?

答:通过设置日志级别,可以筛选出我们所需的信息。例如,若仅需关注 error 级别的日志,系统就会自动过滤出相关记录,从而节省开发者筛选信息的时间

2.3.1、日志级别的分类

Spring Boot集成/输出/日志级别控制/持久化开发实践

日志级别从高到低依次为:FATALERRORWARNINFODEBUGTRACE

  • FATAL致命错误,表示需要立即处理的系统级严重问题
  • ERROR错误信息,记录较高级别的错误,但不会影响系统继续运行
  • WARN警告信息,表示可能存在www.chinasem.cn但不影响系统使用的问题
  • INFO常规信息记录应用程序正常运行时的状态(如系统启动完成、请求处理完毕等)
  • DEBUG:调试信息,用于开发和排查问题时输出关键数据
  • TRACE追踪信息,提供比DEBUG更细粒度的日志记录(若无特殊需求,建议使用DEBUG级别)

2.3.2、日志级别的使用

Logger 对象针对不同级别提供了相应的日志输出方法

@Controller
public class LoggUNVuDderController {
    private Logger  logger = LoggerFactory.getLogger(LoggerController.class);
    @PostConstruct
    public void loggerTest(){
        logger.trace("================= trace ===============");
        logger.debug("================= debug ===============");
        logger.info("================= info ===============");
        logger.warn("================= warn ===============");
        logger.error("================= error ===============");
    }
}

Spring Boot集成/输出/日志级别控制/持久化开发实践

结果显示仅输出了 info、warn 、error 和 debug 级别的日志,这是因为我们在 properties 配置文件中配置了 logging.level.root=debug,因此才显示出这四类日志,但日志级别配置默认为 info,系统会输出等于或高于该级别的日志信息

2.5、日志配置

2.5.1、配置日志级别

日志级别配置只需在配置文件中设置 "logging.level" 项即可,即可得出上文运行结果,示例如下:

Spring Boot集成/输出/日志级别控制/持久化开发实践

2.5.2、日志持久化

以上的日志都是输出在控制台上的,但在实际应用中,控制台输出的日志需要被保存下来以便后续问题排查,这种将日志存储起来的过程称为日志持久化

配置日志文件的路径和文件名

Spring Boot集成/输出/日志级别控制/持久化开发实践

运行后,发现 logger 目录下自动创建了 springboot.log 文件,文件中也保存了运行的日志信息:

Spring Boot集成/输出/日志级别控制/持久化开发实践

Spring Boot集成/输出/日志级别控制/持久化开发实践

配置日志文件的保存路径

Spring Boot集成/输出/日志级别控制/持久化开发实践

该方法仅能设置日志的存储路径,默认生成固定文件名的 spring.log,程序运行时,会在指定路径下自动创建该日志文件

Spring Boot集成/输出/日志级别控制/持久化开发实践

我们使用记事本打开观察:可见刚刚程序运行的日志信息都存储到该文件中

Spring Boot集成/输出/日志级别控制/持久化开发实践

请注意:

当同时配置 logging.file.namelogging.file.path 时,仅其中一个配置会生效,系统会优先采用 logging.file.name 的设置

2.6、Slf4j 注解

Lombok 的 @Slf4j 注解会自动为我们生成一个日志对象 log,可以直接使用

@Slf4j
@Controller
public class LoggerController {
    @PostConstruct
    public void loggerTest(){
       log.info("---------------注解生成日志对象");
    }
}

查看控制台输出结果:

Spring Boot集成/输出/日志级别控制/持久化开发实践

Spring Boot集成/输出/日志级别控制/持久化开发实践

到此这篇关于Spring Boot集成/输出/日志级别控制/持久化开发实践的文章就介绍到这了,更多相关Spring Boot日志级别内容请搜索China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程China编程(www.chinasem.cn)!

这篇关于Spring Boot集成/输出/日志级别控制/持久化开发实践的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1155555

相关文章

破茧 JDBC:MyBatis 在 Spring Boot 中的轻量实践指南

《破茧JDBC:MyBatis在SpringBoot中的轻量实践指南》MyBatis是持久层框架,简化JDBC开发,通过接口+XML/注解实现数据访问,动态代理生成实现类,支持增删改查及参数... 目录一、什么是 MyBATis二、 MyBatis 入门2.1、创建项目2.2、配置数据库连接字符串2.3、入

Springboot项目启动失败提示找不到dao类的解决

《Springboot项目启动失败提示找不到dao类的解决》SpringBoot启动失败,因ProductServiceImpl未正确注入ProductDao,原因:Dao未注册为Bean,解决:在启... 目录错误描述原因解决方法总结***************************APPLICA编

深度解析Spring Security 中的 SecurityFilterChain核心功能

《深度解析SpringSecurity中的SecurityFilterChain核心功能》SecurityFilterChain通过组件化配置、类型安全路径匹配、多链协同三大特性,重构了Spri... 目录Spring Security 中的SecurityFilterChain深度解析一、Security

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Apache Ignite 与 Spring Boot 集成详细指南

《ApacheIgnite与SpringBoot集成详细指南》ApacheIgnite官方指南详解如何通过SpringBootStarter扩展实现自动配置,支持厚/轻客户端模式,简化Ign... 目录 一、背景:为什么需要这个集成? 二、两种集成方式(对应两种客户端模型) 三、方式一:自动配置 Thick

Spring WebClient从入门到精通

《SpringWebClient从入门到精通》本文详解SpringWebClient非阻塞响应式特性及优势,涵盖核心API、实战应用与性能优化,对比RestTemplate,为微服务通信提供高效解决... 目录一、WebClient 概述1.1 为什么选择 WebClient?1.2 WebClient 与

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

Java.lang.InterruptedException被中止异常的原因及解决方案

《Java.lang.InterruptedException被中止异常的原因及解决方案》Java.lang.InterruptedException是线程被中断时抛出的异常,用于协作停止执行,常见于... 目录报错问题报错原因解决方法Java.lang.InterruptedException 是 Jav

深入浅出SpringBoot WebSocket构建实时应用全面指南

《深入浅出SpringBootWebSocket构建实时应用全面指南》WebSocket是一种在单个TCP连接上进行全双工通信的协议,这篇文章主要为大家详细介绍了SpringBoot如何集成WebS... 目录前言为什么需要 WebSocketWebSocket 是什么Spring Boot 如何简化 We

java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)

《java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)》:本文主要介绍java中pdf模版填充表单踩坑的相关资料,OpenPDF、iText、PDFBox是三... 目录准备Pdf模版方法1:itextpdf7填充表单(1)加入依赖(2)代码(3)遇到的问题方法2:pd