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

相关推荐
luod14 小时前
RabbitMQ简单生产者和消费者实现
java·rabbitmq
弥巷14 小时前
【Android】深入理解Window和WindowManager
android·java
未来之窗软件服务14 小时前
操作系统应用(三十六)golang语言ER实体图开发—东方仙盟筑基期
后端·golang·mermaid·仙盟创梦ide·东方仙盟·操作系统应用
user_永14 小时前
Maven 发包
后端
幌才_loong14 小时前
.NET8 牵手 Log4Net:日志界 “最佳 CP” 出道,调试再也不秃头!
后端
武子康14 小时前
大数据-173 Elasticsearch 映射与文档增删改查实战(基于 7.x/8.x)JSON
大数据·后端·elasticsearch
卡皮巴拉_14 小时前
日志系统最佳实践:我如何用 ELK + Filebeat 做“秒级可观测”
后端
泽济天下14 小时前
【经验分享】基于Spring Boot 4.0快速实现最简版的OAuth2 Server和Client
spring boot·springboot·oauth2
写代码的皮筏艇15 小时前
数据库连接
后端
盛小夏2点0版15 小时前
💌 Python 表白神器:一行命令,满屏爱心 + 打字机情话
后端