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日志出配置处理。

相关代码

	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 依赖

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

移除jul over slf4j 依赖

    <dependency>
      <groupId>org.slf4j</groupId>
      <artifactId>jul-to-slf4j</artifactId>
      <version>${slf4j.version}</version>
    </dependency>

参考资料:

Log4j-Jul

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-13 12:36:02       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-13 12:36:02       72 阅读
  3. 在Django里面运行非项目文件

    2024-07-13 12:36:02       58 阅读
  4. Python语言-面向对象

    2024-07-13 12:36:02       69 阅读

热门阅读

  1. 面试真题 | ARM体系架构基础知识

    2024-07-13 12:36:02       27 阅读
  2. 国内Ubuntu安装 stable-diffusion教程,换成国内镜像

    2024-07-13 12:36:02       22 阅读
  3. 【微服务】Spring Cloud中如何使用Eureka

    2024-07-13 12:36:02       20 阅读
  4. 视觉定位是否比GPS更精确?

    2024-07-13 12:36:02       20 阅读
  5. string的模拟实现

    2024-07-13 12:36:02       15 阅读
  6. 源码编译安装LAMP

    2024-07-13 12:36:02       22 阅读
  7. 益铭祥元宇宙

    2024-07-13 12:36:02       27 阅读
  8. Jupyter Notebook基础:用IPython实现动态编程

    2024-07-13 12:36:02       27 阅读
  9. LCP 61. 气温变化趋势

    2024-07-13 12:36:02       24 阅读