启动Spring boot项目报错:java.lang.IllegalArgumentException: LoggerFactory is not a Logback

x33g5p2x  于2022-02-20 转载在 Spring  
字(1.2k)|赞(0)|评价(0)|浏览(480)
  1. java.lang.IllegalArgumentException: LoggerFactory is not a Logback LoggerContext but Logback is on
  2. the classpath. Either remove Logback or the competing implementation (class
  3. org.apache.logging.slf4j.Log4jLoggerFactory loaded from file:/D:/develop/apache-maven-
  4. 3.5.3/repo/org/apache/logging/log4j/log4j-slf4j-impl/2.7/log4j-slf4j-impl-2.7.jar). If you are
  5. using WebLogic you will need to add 'org.slf4j' to prefer-application-packages in WEB-
  6. INF/weblogic.xml:
  7. org.apache.logging.slf4j.Log4jLoggerFactory

解决:

在 Spring Boot 中,程序默认使用 Logback 来记录日志并用 INFO 级别输出到控制台,某些情况下我们可能想用其他日志实现框架替换 Logback,在 Spring Boot 中,因为程序使用了自动配置,所以我们可以很方便地替换日志实现,下面以使用 log4j 替换 Logback 为例。

  1. 去除对默认日志的依赖
  1. <dependency>
  2. <groupId>org.springframework.boot</groupId>
  3. <artifactId>spring-boot-starter</artifactId>
  4. <exclusions>
  5. <exclusion>
  6. <groupId>org.springframework.boot</groupId>
  7. <artifactId>spring-boot-starter-logging</artifactId>
  8. </exclusion>
  9. </exclusions>
  10. </dependency>
  1. 添加对 log4j 的依赖
  1. <!-- 添加 log4j 依赖 -->
  2. <dependency>
  3. <groupId>org.springframework.boot</groupId>
  4. <artifactId>spring-boot-starter-log4j</artifactId>
  5. </dependency>

到此,Spring Boot 项目的日志框架就已经替换成 log4j 了,如需要定义日志输出,只需添加 log4j.properties 文件并在该文件中添加相应配置即可。

相关文章