黑马头条项目微服务启动时控制台给出警告信息SLF4J Class path contains multiple SLF4J bindings

文章目录

  • 1. 错误呈现
  • 2. 错误产生的原因
  • 3. 解决办法(可应用于其它微服务)
    • 3.1 排除 Log4j2 的依赖
    • 3.2 引入Logback的依赖
    • 3.3 重启项目

视频教程:Day1-12-app端登录-功能实现

1. 错误呈现

SLF4J: Class path contains multiple SLF4J bindings.
SLF4J: Found binding in [jar:file:/F:/MavenRepository/ch/qos/logback/logback-classic/1.2.3/logback-classic-1.2.3.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Found binding in [jar:file:/F:/MavenRepository/org/apache/logging/log4j/log4j-slf4j-impl/2.13.3/log4j-slf4j-impl-2.13.3.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation.
SLF4J: Actual binding is of type [ch.qos.logback.classic.util.ContextSelectorStaticBinder]

黑马头条项目微服务启动时控制台给出警告信息SLF4J Class path contains multiple SLF4J bindings_第1张图片

2. 错误产生的原因

根据控制台给出的信息,可以看到错误尝试的原因是类路径下 SLF4J 有多个绑定

通俗点来讲,SLF4J 是一个日志门面(可以理解为抽象层),但是项目中却有 SLF4J 的两个不同实现(Logback 和 Log4j2),SpringBoot 不知道使用哪一个

由于 Logback 是 SpringBoot 默认的日志实现框架,发生冲突时,SpringBoot 选择 Logback 作为日志框架的具体实现

黑马头条项目微服务启动时控制台给出警告信息SLF4J Class path contains multiple SLF4J bindings_第2张图片


对 SLF4J 不了解的同学可以看一下我的另一篇博文:在SpringBoot项目优雅地记录日志(日志框架选型、SpringBoot默认的日志实现框架、如何使用日志框架、如何切换日志的具体实现框架、与日志相关的配置、记录日志的最佳实践)

3. 解决办法(可应用于其它微服务)

由于 SpringBoot 默认使用 Logback 作为日志实现框架,所以我们采用 Logback,不采用 Log4j2

3.1 排除 Log4j2 的依赖

heima-leadnews.xml 文件中排除 Log4j2 的依赖

黑马头条项目微服务启动时控制台给出警告信息SLF4J Class path contains multiple SLF4J bindings_第3张图片

<dependency>
    <groupId>org.springframework.bootgroupId>
    <artifactId>spring-boot-starter-log4j2artifactId>
dependency>

3.2 引入Logback的依赖

其实 SpringBoot 默认已经引入了 Logback 的依赖,不过被手动排除了,我们取消排除 Logback 的依赖就行了(有两处地方需要修改)

heima-leadnews.xml 文件中

黑马头条项目微服务启动时控制台给出警告信息SLF4J Class path contains multiple SLF4J bindings_第4张图片

黑马头条项目微服务启动时控制台给出警告信息SLF4J Class path contains multiple SLF4J bindings_第5张图片

<exclusion>
    <groupId>org.springframework.bootgroupId>
    <artifactId>spring-boot-starter-loggingartifactId>
exclusion>

3.3 重启项目

重启项目后,警告信息就不会出现了

你可能感兴趣的:(Java,SpringBoot,黑马头条,java,spring,boot,微服务)