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

相关推荐
薯条不要番茄酱21 分钟前
数据结构-1.初始包装类与泛型
java·开发语言·数据结构·后端·程序人生·学习方法
MarcoPage40 分钟前
60、PHP 实现 单词查找树算法
java·算法·php
双普拉斯1 小时前
认识消息队列:Spring Boot 实现 MQ 消息队列,解锁异步、削峰、广播等高级功能!
spring boot·微服务·架构
正在走向自律2 小时前
Java二十三种设计模式-享元模式(12/23)
java·设计模式·享元模式
蜡笔-小欣2 小时前
【数据结构】哈希表
java·数据结构·学习
非凡任庆2 小时前
lambda语法,java8Stream流,maven
java·算法·maven
vx_bscxy3222 小时前
node.js蒲公英旅游系统—计算机毕业设计源码15565
java·spring boot·后端·node.js·php·课程设计·旅游
编程经验分享2 小时前
基于 Redis 的分布式锁 Spring Boot 集成 Redisson 使用分布式锁确保对共享资源的互斥访问
spring boot·redis·分布式
春哥的魔法书2 小时前
Spring Boot 自动配置原理及过程
java·spring boot·后端·自动配置
Java&Develop3 小时前
IDEA左下角不显示本地修改的localChanges信息-git
java