slf4j与logback冲突问题

版权声明:虽然坑有点多,不过转载请声明原作者 https://blog.csdn.net/jyj1100/article/details/83217624

slf4j与logback冲突问题

最近发现配置日志中slf4j和logback冲突,导致日志无法打出。

SLF4J: Class path contains multiple SLF4J bindings.
SLF4J: Found binding in [jar:file:/.m2/repository/org/slf4j/slf4j-log4j12/1.7.10/slf4j-log4j12-1.7.10.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Found binding in [jar:file:/.m2/repository/ch/qos/logback/logback-classic/1.0.13/logback-classic-1.0.13.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation.

发现需要排除logback包,经过检查,发现logback包在opentsdb中。排除后解决问题。

<dependency>
    <groupId>net.opentsdb</groupId>
    <artifactId>opentsdb</artifactId>
    <version>2.3.1</version>
    <exclusions>
        <exclusion>
            <groupId>ch.qos.logback</groupId>
            <artifactId>logback-classic</artifactId>
        </exclusion>
        <exclusion>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-core</artifactId>
    </exclusion>
    </exclusions>
</dependency>

logback包出现的时候很少,所以做排除操作的时候一开始没有注意。

其他日志问题,其他时候更多是log4j包之间的冲突,因为很多组件自带日志系统,当集合在一起时就会冲突,一般采用的解决方法是排除所有组件的日志包,再重新导入log4j包。

 <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.17</version>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-api</artifactId>
            <version>1.7.21</version>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-log4j12</artifactId>
            <version>1.7.10</version>
        </dependency>

具体需要排除的组件还有待总结。

猜你喜欢

转载自blog.csdn.net/jyj1100/article/details/83217624