解決slf4j 衝突

可能出現的異常:

發現配置的logback.xml文件沒有起作用,於是分析了一下啓動log,發現log中出現了SLF4J衝突異常:

  1. SLF4J: Class path contains multiple SLF4J bindings.
  2. SLF4J: Failed to load class “org.slf4j.impl.StaticLoggerBinder”

原因分析:

既然是衝突,那可能就是項目中依賴了多個不同版本的slf4j類庫,那如何分析到底是哪幾個類庫依賴了slf4j呢?我們可以使用dependency:tree命令:

$ mvn dependency:tree

解決:

經過依賴tree的分析,發現Zookeeper和Dubbo類庫各自都引用了slf4j類庫,於是使用<exclusions>標籤排除掉傳遞依賴。

  <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>dubbo</artifactId>
            <version>2.8.4</version>
            <exclusions>
                <exclusion>
                    <groupId>org.slf4j</groupId>
                    <artifactId>slf4j-log4j12</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>org.apache.zookeeper</groupId>
            <artifactId>zookeeper</artifactId>
            <version>3.4.6</version>
            <exclusions>
                <exclusion>
                    <groupId>org.slf4j</groupId>
                    <artifactId>slf4j-log4j12</artifactId>
                </exclusion>
                <exclusion>
                    <groupId>log4j</groupId>
                    <artifactId>log4j</artifactId>
                </exclusion>
            </exclusions>
        </dependency>

其它各種依賴衝突都可以使用這種方式解決。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章