SpringBoot:SpringBoot2.7.x如何将logback升级到1.3.x以上版本

SpringBoot2.7.x默认使用的是logback-1.2.x及以下版本,而如果使用logback-1.3.x及以上版本,启动就会报错。主要原因是SpringBoot2.7.x会依赖logback-classic-1.2.x中的类org.slf4j.impl.StaticLoggerBinder,而logback-classic-1.3.x中已经将此类删除了。

一、报错原因分析

下面通过分析源代码查找报错原因,组件版本如下:

spring-boot-2.7.18

logback-classic-1.2.11

SpringBoot启动时会调用方法LoggingApplicationListener.onApplicationEnvironmentPreparedEvent,其中会获取到LoggingSystem的实例:

而生成LoggingSystem实例的方法是LoggingSystem.get

其中SYSTEM_PROPERTY=org.springframework.boot.logging.LoggingSystem

若SYSTEM_PROPERTY的值是LoggingSystem的实现类的类名,比如:org.springframework.boot.logging.logback.LogbackLoggingSystem,则会创建这个类的实例;

若SYSTEM_PROPERTY的值是NONE,则生成NoOpLoggingSystem;

否则,springboot会在类路径中自己去查找有哪些日志组件,然后实例化。

在onApplicationEnvironmentPreparedEvent中获取到LoggingSystem实例后,就会调用initialize方法:

在其中会调用initializeSystem方法

其中CONFIG_PROPERTY=logging.config,也就是从环境变量logging.config中获取logback的配置文件,然后使用LogbackLoggingSystem.initialize对logback进行初始化

查看getLoggerContext()的源代码

可以看到StaticLoggerBinder是在这个地方被用到了。

二、解决方案

通过分析上面的源代码就可以知道,如果想让SpringBoot2.7.x使用logback-classic-1.3.x及以上版本,则需要先将环境变量org.springframework.boot.logging.LoggingSystem的值设置成none,也就是不让SpringBoot帮忙初始化logback,改由应用自己初始化logback。

另外,logback-classic升级到1.3.x以上版本,slf4j也要升级到1.8.x及以上版本,原因可以参考《Java:logback-classic与slf4j版本对应关系》。

最后,如果logback配置文件的路径以前是通过环境变量logging.config配置的,将需要logback配置文件的路径通过环境变量logback.configurationFile进行配置:

其中CONFIG_FILE_PROPERTY=logback.configurationFile

上述源代码属于logback-classic组件,版本如下:

logback-classic-1.3.15

相关推荐
FQNmxDG4S9 小时前
Java多线程编程:Thread与Runnable的并发控制
java·开发语言
虹科网络安全10 小时前
艾体宝干货|数据复制详解:类型、原理与适用场景
java·开发语言·数据库
axng pmje10 小时前
Java语法进阶
java·开发语言·jvm
HackTorjan10 小时前
深度神经网络的反向传播与梯度优化原理
人工智能·spring boot·神经网络·机器学习·dnn
rKWP8gKv710 小时前
Java微服务性能监控:Prometheus与Grafana集成方案
java·微服务·prometheus
老前端的功夫11 小时前
【Java从入门到入土】28:Stream API:告别for循环的新时代
java·开发语言·python
qq_4352879211 小时前
第9章 夸父逐日与后羿射日:死循环与进程终止?十个太阳同时值班的并行冲突
java·开发语言·git·死循环·进程终止·并行冲突·夸父逐日
小江的记录本11 小时前
【Kafka核心】架构模型:Producer、Broker、Consumer、Consumer Group、Topic、Partition、Replica
java·数据库·分布式·后端·搜索引擎·架构·kafka
yaoxin52112311 小时前
397. Java 文件操作基础 - 创建常规文件与临时文件
java·开发语言·python
极客先躯13 小时前
高级java每日一道面试题-2025年11月24日-容器与虚拟化题[Dockerj]-runc 的作用是什么?
java·oci 的命令行工具·最小可用·无守护进程·完全标准·创建容器的核心流程·runc 核心职责思维导图