Spring Boot 3.0 版本SLF4J 对于JUL 日志 Over的处理问题解决

文章目录

  • [Spring Boot 3.0 版本SLF4J 对于JUL 日志 Over的处理问题解决](#Spring Boot 3.0 版本SLF4J 对于JUL 日志 Over的处理问题解决)

Spring Boot 3.0 版本SLF4J 对于JUL 日志 Over的处理问题解决

问题背景

升级Spring Boot 到 3.3.1 版本后,发现原来的JUL日志输出无法在Over到SLF4J的实现类。

问题调研

通过多个Spring Boot的版本比对,发现自3.0版本开始,Spring Boot就移除了org.springframework.boot.logging.Slf4JLoggingSystem 类,在3.0 版本前,Spring Boot 由该类的configureJdkLoggingBridgeHandler() 方法来完成JUL日志出配置处理。

相关代码

java 复制代码
	private void configureJdkLoggingBridgeHandler() {
		try {
			if (isBridgeJulIntoSlf4j()) {
				removeJdkLoggingBridgeHandler();
				SLF4JBridgeHandler.install();
			}
		}
		catch (Throwable ex) {
			// Ignore. No java.util.logging bridge is installed.
		}
	}

其中的SLF4JBridgeHandler 就是jul-to-slf4j 依赖的中实现JUL Over到SLF4J的处理类。

解决方案

根据实际的SLF4J的 实现,选择将JUL 直接Over到对应的实现。下面就根据Log4j2作为实现来处理。

添加jul over log4j2 依赖

xml 复制代码
    <!-- 添加jul over log4j2  -->
    <dependency>
      <groupId>org.apache.logging.log4j</groupId>
      <artifactId>log4j-jul</artifactId>
      <version>${log4j2.version}</version>
    </dependency>

移除jul over slf4j 依赖

xml 复制代码
    <dependency>
      <groupId>org.slf4j</groupId>
      <artifactId>jul-to-slf4j</artifactId>
      <version>${slf4j.version}</version>
    </dependency>

参考资料:

Log4j-Jul

相关推荐
神奇小汤圆1 小时前
接口响应慢到崩溃?CompletableFuture 并行编排让效率提升 3 倍
后端
程序员cxuan2 小时前
GPT-5.6 还不发布?不过大家可以先看看 Codex 的白皮书。
人工智能·后端·程序员
白鲸开源2 小时前
Apache SeaTunnel Zeta Engine 的 Basic Auth 是怎么工作的?
java·vue.js·github
妙码生花2 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(八):设计管理员模型、热重载配置
前端·后端·go
白鲸开源2 小时前
一文读懂DolphinScheduler插件机制:如何轻松扩展任务类型与数据源
java·架构·github
ServBay2 小时前
拒绝当二等公民,Windows 开发者如何无痛开启 Claude Code 本地全栈运维?
后端·ai编程·mcp
用户34232323763172 小时前
从数据源到仪表盘——全链路端到端实战整合
后端
Apifox3 小时前
从 Postman 迁移到 Apifox:Workspace、Collection、Environment 现在可以一起导入了
前端·后端·程序员
用户7713970207064 小时前
深入解析 C# Path.ChangeExtension:原来改扩展名可以这么简单
后端