Spring Boot 中的日志配置

文章目录

    • Spring Boot 中日志配置的源码分析
    • 1. Spring Boot 日志框架的选择与自动配置
    • 2. 日志自动配置与默认行为
    • 3. 日志系统的核心组件:Logger 和 LoggerFactory
    • 4. 日志配置文件的解析
      • 配置日志级别
      • 配置日志输出格式和目标
    • 5. 日志级别的控制
      • 自定义日志级别
    • 6. 自定义日志配置与扩展
      • 自定义日志 Appender
      • 自定义日志输出格式

Spring Boot 中日志配置的源码分析

​ Spring Boot 提供了强大的日志系统,可以让开发者非常方便地进行日志记录和管理。Spring Boot 默认使用 SLF4J 与 Logback 来实现日志的记录和输出,同时还允许开发者自定义日志配置以满足不同的需求。在这篇分析中,我们将从 Spring Boot 源码的角度深入分析其日志配置的实现,主要涉及以下几个方面:

  1. Spring Boot 日志框架的选择与自动配置

  2. 日志配置的自动化配置与默认行为

  3. 日志系统的核心组件:Logger 和 LoggerFactory

  4. 日志配置文件的解析

  5. Spring Boot 日志级别的控制

  6. 自定义日志配置与扩展

1. Spring Boot 日志框架的选择与自动配置

Spring Boot 默认采用 SLF4J 与 Logback 作为日志框架。这一选择基于以下原因:

​ ● SLF4J 是一个日志抽象层,提供统一的日志接口。

​ ● Logback 是 SLF4J 的实现,提供了丰富的日志配置选项和灵活的日志输出方式。

Spring Boot 的日志框架选择通过自动配置来实现,具体可以通过 spring-boot-starter-logging 模块来自动启用。这是 Spring Boot 默认日志系统的核心。

<!-- spring-boot-starter-logging 依赖项 -->
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-logging</artifactId>
</dependency>

2. 日志自动配置与默认行为

Spring Boot 使用 LoggingApplicationListener 来实现日志的自动配置。它通过监听应用程序的启动过程来自动配置日志系统。

@Configuration
@ConditionalOnClass(LoggerFactory.class)
@EnableAutoConfiguration
public class LoggingApplicationListener implements ApplicationListener<ApplicationEnvironmentPreparedEvent> {@Overridepublic void onApplicationEvent(ApplicationEnvironmentPreparedEvent event) {// 初始化日志系统if (loggerContext == null) {configureLogging();}}
}

当应用启动时,LoggingApplicationListener 会被触发,它首先检查日志框架是否已经配置好。如果没有,则会使用默认的日志配置(即 Logback),并初始化日志上下文。

Spring Boot 自动配置的日志默认是通过 Logback 来实现的,日志文件的默认位置为 logs/spring.log,并且日志的默认级别是 INFO。

3. 日志系统的核心组件:Logger 和 LoggerFactory

Logger 是日志记录的核心组件,而 LoggerFactory 用于创建 Logger 实例。Spring Boot 在启动时自动创建并注入 LoggerFactory。

public class LoggerFactory {public static Logger getLogger(String name) {// 使用 SLF4J 的 LoggerFactory 来创建 Loggerreturn LoggerFactory.getLogger(name);}
}

SLF4J 的 Logger 接口提供了多种日志记录方法,如 info()、debug()、warn()、error() 等方法,开发者可以根据需求记录不同级别的日志。

Logger logger = LoggerFactory.getLogger(MyClass.class);
logger.info("This is an info message");
logger.error("This is an error message");

4. 日志配置文件的解析

​ Spring Boot 支持通过 application.properties 或 application.yml 配置文件来配置日志。通过配置文件,开发者可以调整日志级别、输出格式、输出目的地等。

​ 日志的配置文件通常是 logback-spring.xml 或 logback.xml。Spring Boot 支持 logback-spring.xml,并且支持使用 Spring 配置属性进行动态调整。

配置日志级别

# 设置全局日志级别
logging.level.root=INFO# 设置特定类的日志级别
logging.level.org.springframework.web=DEBUG

​ 在 Spring Boot 中,日志级别的配置会通过LogbackLog4j2 来动态调整。在应用启动时,LoggingSystem 会读取配置文件并将相应的日志级别应用到日志系统中。

配置日志输出格式和目标

Spring Boot 还允许通过配置 logback-spring.xml 来设置日志的输出格式和目标。以下是一个 logback-spring.xml 配置文件的示例:

<configuration><!-- 配置日志模式 --><appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender"><encoder><pattern>%d{yyyy-MM-dd HH:mm:ss} - %msg%n</pattern></encoder></appender><logger name="org.springframework" level="INFO" /><logger name="com.myapp" level="DEBUG" /><root level="INFO"><appender-ref ref="CONSOLE"/></root></configuration>

在这个配置中,CONSOLE appender 会将日志输出到控制台,日志格式为 yyyy-MM-dd HH:mm:ss - message,同时设置了不同的日志级别和输出目的地。

5. 日志级别的控制

Spring Boot 允许开发者通过 application.properties 文件来控制日志级别。常见的日志级别有:TRACE、DEBUG、INFO、WARN、ERROR 和 OFF。这些日志级别定义了日志记录的详细程度,级别越低,输出的信息越详细。

# 设置日志级别
logging.level.org.springframework.web=DEBUG
logging.level.com.example=TRACE

​ 在这里,org.springframework.web 包的日志级别被设置为 DEBUG,com.example 包的日志级别被设置为 TRACE。这些设置会覆盖 logback-spring.xml 文件中的配置。

自定义日志级别

开发者可以根据需要自定义日志级别。通过 logging.level 配置项,可以灵活地控制不同包、类的日志级别。

6. 自定义日志配置与扩展

Spring Boot 支持通过自定义日志配置文件来扩展和定制日志功能。开发者可以编写自己的 logback-spring.xml 或 log4j2-spring.xml 文件,并在应用启动时加载这些文件。

自定义日志 Appender

Spring Boot 支持自定义日志 Appender,开发者可以定义日志输出的目的地(如文件、数据库、远程服务器等)。以下是一个自定义 RollingFileAppender 的示例:

<appender name="ROLLING" class="ch.qos.logback.core.rolling.RollingFileAppender"><file>logs/myapp.log</file><rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"><fileNamePattern>logs/myapp-%d{yyyy-MM-dd}.log</fileNamePattern></rollingPolicy><encoder><pattern>%d{yyyy-MM-dd HH:mm:ss} - %msg%n</pattern></encoder></appender>

自定义日志输出格式

日志输出的格式可以通过 PatternLayoutEncoder 进行自定义。以下是一个示例:

<encoder><pattern>%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n</pattern>
</encoder>

这个配置会设置日志的输出格式,包括时间戳、线程名称、日志级别、日志记录器名称和消息内容。

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

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

相关文章

从零到一:我的元宵灯谜小程序诞生记

缘起&#xff1a;一碗汤圆引发的灵感 去年元宵节&#xff0c;我正捧着热腾腾的汤圆刷朋友圈&#xff0c;满屏都是"转发锦鲤求灯谜答案"的动态。看着大家对着手机手忙脚乱地切换浏览器查答案&#xff0c;我突然拍案而起&#xff1a;为什么不做一个能即时猜灯谜的微信…

CSS3+动画

浏览器内核以及其前缀 css标准中各个属性都要经历从草案到推荐的过程&#xff0c;css3中的属性进展都不一样&#xff0c;浏览器厂商在标准尚未明确的情况下提前支持会有风险&#xff0c;浏览器厂商对新属性的支持情况也不同&#xff0c;所有会加厂商前缀加以区分。如果某个属性…

2025.2.8——二、Confusion1 SSTI模板注入|Jinja2模板

题目来源&#xff1a;攻防世界 Confusion1 目录 一、打开靶机&#xff0c;整理信息 二、解题思路 step 1&#xff1a;查看网页源码信息 step 2&#xff1a;模板注入 step 3&#xff1a;构造payload&#xff0c;验证漏洞 step 4&#xff1a;已确认为SSTI漏洞中的Jinjia2…

c++初始

目录 一数据类型 1. 2.sizeof 3.布尔 4.字符串类型 二.数据输入与输出 1.输出 2.输入 三.运算 1.加减乘除取模&#xff0c;&#xff0c;--都一样 2.逻辑非与或&#xff0c;与C语言一样 3.比较运算符&#xff0c;与C语言一样 4.三目运算符&#xff08;与C语言一样&a…

数字电路-基础逻辑门实验

基础逻辑门是数字电路设计的核心元件&#xff0c;它们执行的是基本的逻辑运算。通过这些基本运算&#xff0c;可以构建出更为复杂的逻辑功能。常见的基础逻辑门包括与门&#xff08;AND&#xff09;、或门&#xff08;OR&#xff09;、非门&#xff08;NOT&#xff09;、异或门…

HC32功能复用说明

目录 引脚有哪些功能如何选择功能代码 引脚有哪些功能 数据手册中&#xff0c;每一个引脚功能有至多64个&#xff0c;对应列Func0~Func63 其中&#xff0c;Func0 ~Func31在《表 2-1 引脚功能表》中列出 Func32~Func63在《表 2-2 Func32~63 表》中列出。 Func32~Func63中的功…

数据库管理-第293期 奇怪的sys.user$授权+(20250210)

数据库管理293期 2025-02-10 数据库管理-第293期 奇怪的sys.user$授权&#xff08;20250210&#xff09;1 清空shared pool2 SR反馈总结 数据库管理-第293期 奇怪的sys.user$授权&#xff08;20250210&#xff09; 作者&#xff1a;胖头鱼的鱼缸&#xff08;尹海文&#xff09…

AutoMQ 如何实现没有写性能劣化的极致冷读效率

前言 追赶读&#xff08;Catch-up Read&#xff0c;冷读&#xff09;是消息和流系统常见和重要的场景。 削峰填谷&#xff1a;对于消息来说&#xff0c;消息通常用作业务间的解耦和削峰填谷。削峰填谷要求消息队列能将上游发送的数据堆积住&#xff0c;让下游在容量范围内消费…

【大模型】本地部署DeepSeek-R1:8b大模型及搭建Open-WebUI交互页面

本地部署DeepSeek-R1:8b大模型 一、摘要及版本选择说明1.1 摘要1.2 版本选择 二、下载并安装Ollama三、运行DeepSeek-R1:8b大模型四、安装Open WebUI增强交互体验五、关闭Ollama开机自动启动六、DeepSeek大模型启停步骤 一、摘要及版本选择说明 1.1 摘要 作为一名对 AI 和生成…

DeepSeek大模型的发展的十问十答

DeepSeek大模型是由杭州深度求索人工智能基础技术研究有限公司开发的一款基于Transformer架构的大型语言模型&#xff0c;具体介绍如下&#xff1a; 1. 架构基础 Transformer架构&#xff1a;DeepSeek大模型基于Transformer架构&#xff0c;该架构由Google在2017年提出&#xf…

Avnet RFSoC基于maltab得5G 毫米波 开发工具箱

使用 MATLAB 连接到 AMD Zynq™ RFSoC 评估板。使用 RF 附加卡执行 OTA 测试。使用 HDL Coder 部署算法 版本要求&#xff1a; 大于 2023b 需要以下支持包之一&#xff1a; 适用于 Xilinx 基于 Zynq 的无线电&#xff08;R2023b 及更早版本&#xff09;的通信工具箱支持包适…

directx12 3d开发过程中出现的报错 九

报错&#xff1a; ThrowIfFailed(md3dDevice->CreateGraphicsPipelineState(&basePsoDesc, IID_PPV_ARGS(&mPSO))); 参数错误 当 md3dDevice->CreateGraphicsPipelineState 调用返回 “参数错误” 时&#xff0c;意味着传递给该函数的 D3D12_GRAPHICS_PIPELINE_…

计算机毕业设计Python+Spark知识图谱医生推荐系统 医生门诊预测系统 医生数据分析 医生可视化 医疗数据分析 医生爬虫 大数据毕业设计 机器学习

温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 作者简介&#xff1a;Java领…

Vue事件处理 - 绑定事件

Vue 渐进式JavaScript 框架 基于Vue2的学习笔记 - Vue事件处理 - 绑定事件及事件处理 目录 事件处理 绑定方式 函数表达式 绑定函数名 输入框绑定事件 拿到输入框的值 传值加事件源 事件第三种写法 总结 事件处理 绑定方式 函数表达式 在按钮上使用函数表达式绑定事…

World of Warcraft [CLASSIC] 80 Four Horsemen (Naxxramas)

纳克萨玛斯 天启四骑士 Four Horsemen 图一&#xff1a;10人同生共死 图二&#xff1a;25人同生共死站位 图三&#xff0c;不做同生共死&#xff0c;做永恒者&#xff0c;击杀白马分布图&#xff0c;主要是不熟练乱跑&#xff0c;容易导致减员失败 永恒者&#xff0c;玩家无一…

DeepSeek与AI提示语设计的全面指南

当人人都会用AI时&#xff0c;你如何用得更好更出彩&#xff1f;本文全面介绍了DeepSeek的功能与使用方法&#xff0c;并深入探讨了AI提示语设计的核心技巧与进阶策略。通过精准的任务定义、提示语优化和人机协作&#xff0c;用户可以从AI的基础使用逐步进阶到创新应用&#xf…

DeepSeek-R1两种不同模型变体(deepseek-llm-7b-chat 和 deepseek-llm-7b-base)之间的区别

deepseek-llm-7b-chat 和 deepseek-llm-7b-base 是基于同一参数量级&#xff08;7B&#xff09;的两种不同模型变体&#xff0c;主要区别在于训练目标、适用场景和性能表现。以下是详细对比&#xff1a; 1. 核心区别 特性deepseek-llm-7b-basedeepseek-llm-7b-chat训练目标通用…

HarmonyOS Next 方舟字节码文件格式介绍

在开发中&#xff0c;可读的编程语言要编译成二进制的字节码格式才能被机器识别。在HarmonyOS Next开发中&#xff0c;arkts会编译成方舟字节码。方舟字节码长什么样呢&#xff1f;我们以一个demo编译出的abc文件&#xff1a; 二进制就是长这样&#xff0c;怎么去理解呢&…

TCP/IP 协议图解 | TCP 协议详解 | IP 协议详解

注&#xff1a;本文为 “TCP/IP 协议” 相关文章合辑。 未整理去重。 TCP/IP 协议图解 退休的汤姆 于 2021-07-01 16:14:25 发布 TCP/IP 协议简介 TCP/IP 协议包含了一系列的协议&#xff0c;也叫 TCP/IP 协议族&#xff08;TCP/IP Protocol Suite&#xff0c;或 TCP/IP Pr…

【C++11】lambda和包装器

1.新的类功能 1.1默认的移动构造和移动赋值 原来C类中&#xff0c;有6个默认成员函数&#xff1a;构造函数/析构函数/拷⻉构造函数/拷⻉赋值重载/取地址重 载/const 取地址重载&#xff0c;最后重要的是前4个&#xff0c;后两个⽤处不⼤&#xff0c;默认成员函数就是我们不写…