Spring Boot - 日志功能深度解析与实践指南

文章目录

  • 概述
  • 1. Spring Boot 日志功能概述
  • 2. 默认日志框架:Logback
    • Logback 的核心组件
    • Logback 的配置文件
  • 3. 日志级别及其配置
    • 配置日志级别
      • 3.1 配置文件
      • 3.2 环境变量
      • 3.3 命令行参数
  • 4. 日志格式自定义
    • 自定义日志格式
  • 5. 日志文件输出
  • 6. 日志归档与清理
  • 7. 自定义日志配置
  • 8. 与其他日志框架的集成
    • 8.1 使用 Log4j2
    • 8.2 使用 Java Util Logging
  • 9. 日志性能优化
  • 11. 总结

在这里插入图片描述


概述

Spring Boot 作为 Java 生态中最流行的应用开发框架之一,提供了强大且灵活的日志功能,支持多种日志框架,并且可以轻松配置。接下来我们将基于 Spring Boot 官方文档,深入解析 Spring Boot 的日志功能,并结合实际场景提供详细的配置与实践指南。


1. Spring Boot 日志功能概述

Spring Boot 的日志功能旨在为开发者提供开箱即用的日志解决方案,同时支持高度自定义。其核心特点包括:

  • 默认集成 Logback:Spring Boot 默认使用 Logback 作为日志框架,无需额外配置。
  • 多日志框架支持:除了 Logback,还支持 Log4j2 和 Java Util Logging(JUL)。
  • 灵活的配置:通过配置文件、环境变量或命令行参数轻松调整日志行为。
  • 丰富的功能:支持日志级别控制、日志格式自定义、文件输出、日志归档等。

Spring Boot 的日志功能通过 spring-boot-starter-logging 依赖实现,该依赖会自动引入 Logback 及其相关依赖。


2. 默认日志框架:Logback

Logback 是 Log4j 的继任者,由 Log4j 的原作者开发。它具有更高的性能、更丰富的功能以及更好的扩展性。Spring Boot 默认使用 Logback 作为日志框架,开发者无需额外配置即可使用。

Logback 的核心组件

  • Logger:负责日志记录,开发者通过 Logger 对象输出日志。
  • Appender:定义日志的输出目的地,例如控制台、文件、数据库等。
  • Layout:定义日志的输出格式。

Logback 的配置文件

Logback 支持通过 XML 或 Groovy 文件进行配置。Spring Boot 默认会在 classpath 下查找 logback-spring.xml 文件作为配置文件。如果未找到,则使用内置的默认配置。


3. 日志级别及其配置

日志级别用于控制日志信息的详细程度。Spring Boot 支持以下日志级别(从低到高):

  • TRACE:最详细的日志信息,通常用于调试。
  • DEBUG:用于调试的日志信息。
  • INFO:常规的运行日志信息。
  • WARN:警告信息,表示潜在的问题。
  • ERROR:错误信息,表示发生了错误但应用程序仍可运行。
  • FATAL:严重错误信息,表示应用程序无法继续运行。

配置日志级别

可以通过以下方式配置日志级别:

3.1 配置文件

application.propertiesapplication.yml 中设置日志级别。例如:

logging.level.root=WARN
logging.level.org.springframework=DEBUG
logging.level.com.example=TRACE

3.2 环境变量

通过设置环境变量来调整日志级别。例如:

export LOGGING_LEVEL_ORG_SPRINGFRAMEWORK=DEBUG

3.3 命令行参数

在启动应用时通过命令行参数设置日志级别。例如:

java -jar myapp.jar --logging.level.org.springframework=DEBUG

4. 日志格式自定义

Spring Boot 允许开发者自定义日志输出格式。默认的日志格式如下:

2023-10-01 12:34:56.789  INFO 12345 --- [           main] com.example.MyClass : This is a log message

自定义日志格式

开发者可以通过 application.propertiesapplication.yml 文件自定义日志格式。例如:

logging.pattern.console=%d{yyyy-MM-dd HH:mm:ss} - %msg%n

常用的日志格式占位符包括:

  • %d:日期和时间。
  • %msg:日志消息。
  • %n:换行符。
  • %level:日志级别。
  • %logger:Logger 名称。

5. 日志文件输出

除了控制台输出,Spring Boot 还支持将日志输出到文件。开发者可以通过以下配置启用文件日志记录:

logging.file.name=myapp.log
logging.file.path=/var/logs
  • logging.file.name:指定日志文件的名称。
  • logging.file.path:指定日志文件的存储路径。

如果同时指定了 logging.file.namelogging.file.path,则 logging.file.name 优先级更高。


6. 日志归档与清理

为了避免日志文件过大,Spring Boot 支持日志文件的归档和清理。开发者可以通过以下配置实现:

logging.logback.rollingpolicy.max-file-size=10MB
logging.logback.rollingpolicy.max-history=30
  • max-file-size:指定单个日志文件的最大大小,超过该大小后会自动归档。
  • max-history:指定保留的归档日志文件的最大天数。

7. 自定义日志配置

如果默认的日志配置无法满足需求,开发者可以完全自定义日志配置。Spring Boot 支持通过 XML 或 Groovy 文件配置日志框架。例如,可以在 src/main/resources 目录下创建 logback-spring.xml 文件来配置 Logback。

<configuration><appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"><encoder><pattern>%d{yyyy-MM-dd HH:mm:ss} - %msg%n</pattern></encoder></appender><root level="info"><appender-ref ref="STDOUT" /></root>
</configuration>

8. 与其他日志框架的集成

除了 Logback,Spring Boot 还支持 Log4j2 和 Java Util Logging(JUL)。可以通过以下方式切换日志框架:

8.1 使用 Log4j2

pom.xml 中排除 spring-boot-starter-logging,并引入 spring-boot-starter-log4j2

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter</artifactId><exclusions><exclusion><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-logging</artifactId></exclusion></exclusions>
</dependency>
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-log4j2</artifactId>
</dependency>

8.2 使用 Java Util Logging

application.properties 中配置:

logging.framework=jul

9. 日志性能优化

在高并发场景下,日志记录可能会成为性能瓶颈。以下是一些优化建议:

  • 异步日志:使用异步 Appender 提高日志记录性能。
  • 减少不必要的日志:避免在高频代码路径中记录 DEBUGTRACE 级别的日志。
  • 使用高效的日志格式:避免复杂的日志格式占位符。

11. 总结

  • 合理配置日志级别:根据环境(开发、测试、生产)调整日志级别。
  • 使用自定义日志配置:在复杂场景下,使用 XML 或 Groovy 文件进行配置。
  • 优化日志性能:在高并发场景下,使用异步日志和高效的日志格式。
  • 集中管理日志:在微服务架构中,使用集中式日志管理工具。

参考文档
Spring Boot 官方文档 - 日志功能

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/66270.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

NVIDIA DLI课程《NVIDIA NIM入门》——学习笔记

先看老师给的资料&#xff1a; NVIDIA NIM是 NVIDIA AI Enterprise 的一部分&#xff0c;是一套易于使用的预构建容器工具&#xff0c;目的是帮助企业客户在云、数据中心和工作站上安全、可靠地部署高性能的 AI 模型推理。这些预构建的容器支持从开源社区模型到 NVIDIA AI 基础…

JOIN 和 OUTER JOIN,SQL中常见的连接方式

1. INNER JOIN&#xff08;简称 JOIN&#xff09; INNER JOIN 是 SQL 中最常用的一种连接方式&#xff0c;默认的 JOIN 就是 INNER JOIN。它返回两个表中满足连接条件的匹配记录。 作用&#xff1a;返回两个表中所有满足 ON 条件的记录。特性&#xff1a;如果表中的某些行在连…

【HF设计模式】05-单例模式

声明&#xff1a;仅为个人学习总结&#xff0c;还请批判性查看&#xff0c;如有不同观点&#xff0c;欢迎交流。 摘要 《Head First设计模式》第5章笔记&#xff1a;结合示例应用和代码&#xff0c;介绍单例模式&#xff0c;包括遇到的问题、采用的解决方案、以及达到的效果。…

【FlutterDart】页面切换 PageView PageController(9 /100)

上效果&#xff1a; 有些不能理解官方例子里的动画为什么没有效果&#xff0c;有可能是我写法不对 后续如果有动画效果修复了&#xff0c;再更新这篇&#xff0c;没有动画效果&#xff0c;总觉得感受的丝滑效果差了很多 上代码&#xff1a; import package:flutter/material.…

Electron快速入门——跨平台桌面端应用开发框架

个人简介 &#x1f440;个人主页&#xff1a; 前端杂货铺 &#x1f64b;‍♂️学习方向&#xff1a; 主攻前端方向&#xff0c;正逐渐往全干发展 &#x1f4c3;个人状态&#xff1a; 研发工程师&#xff0c;现效力于中国工业软件事业 &#x1f680;人生格言&#xff1a; 积跬步…

Android NDK开发实战之环境搭建篇(so库,Gemini ai)

文章流程 音视频安卓开发首先涉及到ffmpeg编译打包动态库&#xff0c;先了解动态库之间的cpu架构差异性。然后再搭建可运行的Android 环境。 So库适配 ⽇常开发我们经常会使⽤到第三库&#xff0c;涉及到底层的语⾳&#xff0c;视频等都需要添加so库。⽽so库的体积⼀般来说 ⾮…

【Java回顾】Day2 正则表达式----异常处理

参考资料&#xff1a;菜鸟教程 https://www.runoob.com/java/java-exceptions.html 正则表达式 有一部分没看完 介绍 字符串的模式搜索、编辑或处理文本java.util.regex包&#xff0c;包含了pattern和mathcer类&#xff0c;用于处理正则表达式的匹配操作。 捕获组 把多个字符…

Unity性能优化总结

目录 前言 移动端常见性能优化指标​编辑 包体大小优化 FPS CPU占用率 GPU占用率 内存 发热和耗电量 流量优化 前言 终于有时间了&#xff0c;我将在最近两个项目中进行优化的一些经验进行归纳总结以飨读者。因为我习惯用思维导图&#xff0c;所以归纳的内容主要以图来…

FTP上传下传、SFTP上传下传、进度监控、断点续传、连接池封装JAVA一网打尽(二)FTP高级篇【2/5】

一、摘要&#xff08;本系列汇总说明&#xff09; - 总纲 FTP、SFTP上传下传、进度监控、断点续传、连接池封装JAVA一网打尽&#xff08;一&#xff09;FTP、SFTP上传下传、进度监控、断点续传、连接池封装JAVA一网打尽&#xff08;二&#xff09;FTP、SFTP上传下传、进度监控…

北京航空航天大学惊现技术商业“宫斗剧”!背后隐藏的内幕遭曝光!

北京航空航天大学&#xff08;以下称北航&#xff09;与源亿&#xff08;北京&#xff09;网络科技有限公司&#xff08;以下称源亿&#xff09;的派驻的员工恶意串通&#xff0c;指定北京蚂蚁非标科技有限公司&#xff08;以下称蚂蚁公司&#xff09;挖走源亿公司在现场派驻的…

transfomer深度学习实战水果识别

本文采用RT-DETR作为核心算法框架&#xff0c;结合PyQt5构建用户界面&#xff0c;使用Python3进行开发。RT-DETR以其高效的实时检测能力&#xff0c;在多个目标检测任务中展现出卓越性能。本研究针对水果数据集进行训练和优化&#xff0c;该数据集包含丰富的水果图像样本&#…

Python世界:人生苦短,我用Python

Python世界&#xff1a;人生苦短&#xff0c;我用Python 前言Python优势Python缺点 前言 几句话说清&#xff0c;我们为啥要用Python&#xff1f; Python设计之初心&#xff0c;是为了解决编程门槛&#xff0c;让大家更聚焦业务实现&#xff0c;而非编程细节。当前人工智能火…

TensorFlow深度学习实战(3)——深度学习中常用激活函数详解

TensorFlow深度学习实战&#xff08;3&#xff09;——深度学习中常用激活函数详解 0. 前言1. 引入激活函数1.1 感知器1.2 多层感知器1.3 训练感知器存在的问题 2. 激活函数3. 常见激活函数3.1 sigmoid3.2 tanh3.3 ReLU3.4 ELU和Leaky ReLU 小结系列链接 0. 前言 使用激活函数…

Linux vi/vim 编辑器:功能强大的文本处理工具

Linux vi/vim 编辑器&#xff1a;功能强大的文本处理工具 引言 Linux 系统中的 vi/vim 是一种功能强大的文本编辑器&#xff0c;它广泛应用于程序员、系统管理员和其他需要处理文本文件的用户群体中。vi 是 visual interface 的缩写&#xff0c;而 vim 则是 vi improved 的缩…

C#设计模式(行为型模式):状态模式

C#设计模式&#xff1a;状态模式 在软件开发中&#xff0c;我们经常会遇到对象的行为取决于其状态的情况。例如&#xff0c;一个订单对象可能处于“待支付”、“已支付”、“已发货”等不同状态&#xff0c;而每个状态下订单的行为&#xff08;例如是否可以支付、是否可以发货…

数据结构C语言描述9(图文结合)--二叉树和特殊书的概念,二叉树“最傻瓜式创建”与前中后序的“递归”与“非递归遍历”

前言 这个专栏将会用纯C实现常用的数据结构和简单的算法&#xff1b;有C基础即可跟着学习&#xff0c;代码均可运行&#xff1b;准备考研的也可跟着写&#xff0c;个人感觉&#xff0c;如果时间充裕&#xff0c;手写一遍比看书、刷题管用很多&#xff0c;这也是本人采用纯C语言…

Leetcode打卡:设计一个ATM机器

执行结果&#xff1a;通过 题目 2241 设计一个ATM机器 一个 ATM 机器&#xff0c;存有 5 种面值的钞票&#xff1a;20 &#xff0c;50 &#xff0c;100 &#xff0c;200 和 500 美元。初始时&#xff0c;ATM 机是空的。用户可以用它存或者取任意数目的钱。 取款时&#xff0c…

0. 总框架

第1阶段&#xff0c;c语言层面 (1) c语言基本语法&#xff1a;结构体、指针、宏 (2) 数据结构和算法&#xff1a;hash&#xff0c;rbtree&#xff0c;b/btree&#xff0c;linked list(链表) 1.2.1-1部分数据结构的说明-CSDN博客 1.2.1-2部分数据结构的说明02_链表-CSDN博客…

比Qt更适合小公司的C++界面开发框架wxWidgets

C++行业里,如果一家小公司对某些费用方面问题特别敏感,而且你做的产品属于消费品领域,那么你最好还是选择wxWidgets来替代Qt。 Qt的好处是保罗大部分常用的开发库,它不用你会C++ STL,因为它本身就很成熟,你无需使用STL库去补充功能,所以我经常看到很多小公司的招聘信息…

源码理解 UE4中的 FCookStatsManager::FAutoRegisterCallback RegisterCookStats

官方文档&#xff1a;https://dev.epicgames.com/documentation/zh-cn/unreal-engine/API/Runtime/Core/ProfilingDebugging/FCookStatsManager文档中的注释&#xff1a; When a cook a complete that is configured to use stats (ENABLE_COOK_STATS), it will broadcast this…