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

相关推荐
AI人工智能+电脑小能手4 分钟前
【大白话说Java面试题 第63题】【JVM篇】第23题:工作中用过的JVM常用基本配置参数有哪些?
java·开发语言·jvm·面试
周末也要写八哥7 分钟前
C++变参模板之空参包的特殊情况
java·开发语言·c++
杨运交8 分钟前
[019][数据模块]MyBatis-Plus 拦截器扩展设计:基于函数式接口与 Spring 自动装配
spring boot
书语时11 分钟前
看了 Comparator 源码,我重写了所有业务排序逻辑
java
fliter12 分钟前
为什么我要杀掉 syn:Rust 编译速度之战与 unsynn 的诞生
后端
huzhongqiang15 分钟前
扩展 Python 事件机制:支持等待事件消失
后端·python
likerhood18 分钟前
Java final 关键字:从“不能改”到“安全发布”的深入理解
java·windows·安全
花千树-01038 分钟前
SubAgent 基础:拥有自主工具的子代理
java·langchain·llm·agent·langgraph·subagent·harness
水上冰石38 分钟前
java直接调用本地大模型文件,实现对话机器人
java·aigc·jlama