rom*_*man 12 log4j logback slf4j gradle slf4j-api
tring运行gradle build时出现此错误
我理解它的版本冲突,但不知道如何解决它和哪些
要排除的版本...
gradle依赖树是:
SLF4J: Class path contains multiple SLF4J bindings.
SLF4J: Found binding in [jar:file:/C:/Users/i/.gradle/caches/modules-
2/files-2.1/org.slf4j/slf4j-
log4j12/1.6.1/bd245d6746cdd4e6203e976e21d597a46f115802/slf4j-log4j12-
1.6.1.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Found binding in
[jar:file:/C:/Users/i/.gradle/caches/modules-2/files-
2.1/ch.qos.logback/logback-
classic/1.1.3/d90276fff414f06cb375f2057f6778cd63c6082f/logback-classic-
1.1.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 [org.slf4j.impl.Log4jLoggerFactory]
SLF4J: Detected both log4j-over-slf4j.jar AND slf4j-log4j12.jar on the class
path, preempting StackOverflowError.
compile - Compile classpath for source set 'main'.
+--- com.google.code.gson:gson:2.2.4
+--- com.fasterxml.jackson.core:jackson-core:2.6.0
+--- com.fasterxml.jackson.core:jackson-databind:2.6.0
| +--- com.fasterxml.jackson.core:jackson-annotations:2.6.0
| \--- com.fasterxml.jackson.core:jackson-core:2.6.0
+--- com.fasterxml.jackson.core:jackson-annotations:2.6.0
+--- com.fasterxml.jackson.dataformat:jackson-dataformat-yaml:2.6.0
| +--- com.fasterxml.jackson.core:jackson-core:2.6.0
| \--- org.yaml:snakeyaml:1.15
+--- org.projectlombok:lombok:1.16.10
+--- javax.validation:validation-api:1.1.0.Final
+--- org.apache.commons:commons-lang3:3.4
+--- org.apache.zookeeper:zookeeper:3.4.5
| +--- org.slf4j:slf4j-api:1.6.1 -> 1.7.21
| +--- org.slf4j:slf4j-log4j12:1.6.1
| | +--- org.slf4j:slf4j-api:1.6.1 -> 1.7.21
| | \--- log4j:log4j:1.2.16
| +--- log4j:log4j:1.2.15 -> 1.2.16
| +--- jline:jline:0.9.94
| | \--- junit:junit:3.8.1
| \--- org.jboss.netty:netty:3.2.2.Final
+--- org.apache.httpcomponents:httpcore:4.4.5 -> 4.4.6
+--- org.apache.httpcomponents:httpclient:4.5.3
| +--- org.apache.httpcomponents:httpcore:4.4.6
| +--- commons-logging:commons-logging:1.2
| \--- commons-codec:commons-codec:1.9
+--- commons-io:commons-io:2.5
+--- org.jdom:jdom2:2.0.5
\--- org.slf4j:slf4j-api:1.7.21
default - Configuration for default artifacts.
+--- com.google.code.gson:gson:2.2.4
+--- com.fasterxml.jackson.core:jackson-core:2.6.0
+--- com.fasterxml.jackson.core:jackson-databind:2.6.0
| +--- com.fasterxml.jackson.core:jackson-annotations:2.6.0
| \--- com.fasterxml.jackson.core:jackson-core:2.6.0
+--- com.fasterxml.jackson.core:jackson-annotations:2.6.0
+--- com.fasterxml.jackson.dataformat:jackson-dataformat-yaml:2.6.0
| +--- com.fasterxml.jackson.core:jackson-core:2.6.0
| \--- org.yaml:snakeyaml:1.15
+--- org.projectlombok:lombok:1.16.10
+--- javax.validation:validation-api:1.1.0.Final
+--- org.apache.commons:commons-lang3:3.4
+--- org.apache.zookeeper:zookeeper:3.4.5
| +--- org.slf4j:slf4j-api:1.6.1 -> 1.7.21
| +--- org.slf4j:slf4j-log4j12:1.6.1
| | +--- org.slf4j:slf4j-api:1.6.1 -> 1.7.21
| | \--- log4j:log4j:1.2.16
| +--- log4j:log4j:1.2.15 -> 1.2.16
| +--- jline:jline:0.9.94
| | \--- junit:junit:3.8.1
| \--- org.jboss.netty:netty:3.2.2.Final
+--- org.apache.httpcomponents:httpcore:4.4.5 -> 4.4.6
+--- org.apache.httpcomponents:httpclient:4.5.3
| +--- org.apache.httpcomponents:httpcore:4.4.6
| +--- commons-logging:commons-logging:1.2
| \--- commons-codec:commons-codec:1.9
+--- commons-io:commons-io:2.5
+--- org.jdom:jdom2:2.0.5
\--- org.slf4j:slf4j-api:1.7.21
runtime - Runtime classpath for source set 'main'.
+--- com.google.code.gson:gson:2.2.4
+--- com.fasterxml.jackson.core:jackson-core:2.6.0
+--- com.fasterxml.jackson.core:jackson-databind:2.6.0
| +--- com.fasterxml.jackson.core:jackson-annotations:2.6.0
| \--- com.fasterxml.jackson.core:jackson-core:2.6.0
+--- com.fasterxml.jackson.core:jackson-annotations:2.6.0
+--- com.fasterxml.jackson.dataformat:jackson-dataformat-yaml:2.6.0
| +--- com.fasterxml.jackson.core:jackson-core:2.6.0
| \--- org.yaml:snakeyaml:1.15
+--- org.projectlombok:lombok:1.16.10
+--- javax.validation:validation-api:1.1.0.Final
+--- org.apache.commons:commons-lang3:3.4
+--- org.apache.zookeeper:zookeeper:3.4.5
| +--- org.slf4j:slf4j-api:1.6.1 -> 1.7.21
| +--- org.slf4j:slf4j-log4j12:1.6.1
| | +--- org.slf4j:slf4j-api:1.6.1 -> 1.7.21
| | \--- log4j:log4j:1.2.16
| +--- log4j:log4j:1.2.15 -> 1.2.16
| +--- jline:jline:0.9.94
| | \--- junit:junit:3.8.1
| \--- org.jboss.netty:netty:3.2.2.Final
+--- org.apache.httpcomponents:httpcore:4.4.5 -> 4.4.6
+--- org.apache.httpcomponents:httpclient:4.5.3
| +--- org.apache.httpcomponents:httpcore:4.4.6
| +--- commons-logging:commons-logging:1.2
| \--- commons-codec:commons-codec:1.9
+--- commons-io:commons-io:2.5
+--- org.jdom:jdom2:2.0.5
\--- org.slf4j:slf4j-api:1.7.21
testCompile - Compile classpath for source set 'test'.
+--- com.google.code.gson:gson:2.2.4
+--- com.fasterxml.jackson.core:jackson-core:2.6.0
+--- com.fasterxml.jackson.core:jackson-databind:2.6.0
| +--- com.fasterxml.jackson.core:jackson-annotations:2.6.0
| \--- com.fasterxml.jackson.core:jackson-core:2.6.0
+--- com.fasterxml.jackson.core:jackson-annotations:2.6.0
+--- com.fasterxml.jackson.dataformat:jackson-dataformat-yaml:2.6.0
| +--- com.fasterxml.jackson.core:jackson-core:2.6.0
| \--- org.yaml:snakeyaml:1.15
+--- org.projectlombok:lombok:1.16.10
+--- javax.validation:validation-api:1.1.0.Final
+--- org.apache.commons:commons-lang3:3.4
+--- org.apache.zookeeper:zookeeper:3.4.5
| +--- org.slf4j:slf4j-api:1.6.1 -> 1.7.21
| +--- org.slf4j:slf4j-log4j12:1.6.1
| | +--- org.slf4j:slf4j-api:1.6.1 -> 1.7.21
| | \--- log4j:log4j:1.2.16
| +--- log4j:log4j:1.2.15 -> 1.2.16
| +--- jline:jline:0.9.94
| | \--- junit:junit:3.8.1 -> 4.11
| | \--- org.hamcrest:hamcrest-core:1.3
| \--- org.jboss.netty:netty:3.2.2.Final
+--- org.apache.httpcomponents:httpcore:4.4.5 -> 4.4.6
+--- org.apache.httpcomponents:httpclient:4.5.3
| +--- org.apache.httpcomponents:httpcore:4.4.6
| +--- commons-logging:commons-logging:1.2
| \--- commons-codec:commons-codec:1.9
+--- commons-io:commons-io:2.5
+--- org.jdom:jdom2:2.0.5
+--- org.slf4j:slf4j-api:1.7.21
\--- junit:junit:4.11 (*)
testRuntime - Runtime classpath for source set 'test'.
+--- com.google.code.gson:gson:2.2.4
+--- com.fasterxml.jackson.core:jackson-core:2.6.0
+--- com.fasterxml.jackson.core:jackson-databind:2.6.0
| +--- com.fasterxml.jackson.core:jackson-annotations:2.6.0
| \--- com.fasterxml.jackson.core:jackson-core:2.6.0
+--- com.fasterxml.jackson.core:jackson-annotations:2.6.0
+--- com.fasterxml.jackson.dataformat:jackson-dataformat-yaml:2.6.0
| +--- com.fasterxml.jackson.core:jackson-core:2.6.0
| \--- org.yaml:snakeyaml:1.15
+--- org.projectlombok:lombok:1.16.10
+--- javax.validation:validation-api:1.1.0.Final
+--- org.apache.commons:commons-lang3:3.4
+--- org.apache.zookeeper:zookeeper:3.4.5
| +--- org.slf4j:slf4j-api:1.6.1 -> 1.7.21
| +--- org.slf4j:slf4j-log4j12:1.6.1
| | +--- org.slf4j:slf4j-api:1.6.1 -> 1.7.21
| | \--- log4j:log4j:1.2.16
| +--- log4j:log4j:1.2.15 -> 1.2.16
| +--- jline:jline:0.9.94
| | \--- junit:junit:3.8.1 -> 4.11
| | \--- org.hamcrest:hamcrest-core:1.3
| \--- org.jboss.netty:netty:3.2.2.Final
+--- org.apache.httpcomponents:httpcore:4.4.5 -> 4.4.6
+--- org.apache.httpcomponents:httpclient:4.5.3
| +--- org.apache.httpcomponents:httpcore:4.4.6
| +--- commons-logging:commons-logging:1.2
| \--- commons-codec:commons-codec:1.9
+--- commons-io:commons-io:2.5
+--- org.jdom:jdom2:2.0.5
+--- org.slf4j:slf4j-api:1.7.21
\--- junit:junit:4.11 (*)
Run Code Online (Sandbox Code Playgroud)
但我甚至不知道如何阅读它...
你能帮帮忙吗?
Joh*_*nny 14
首先,SLF4J是各种日志框架(例如java.util.logging,logback,log4j)的简单外观,允许最终用户在部署时插入所需的日志记录框架.
用简单的词语是什么意思?
当您使用SLF4J时,您的代码将依赖于SLF4J(SLF4J-API)提供的一个常见日志记录界面,另一方面,您将选择的日志框架插入SLF4J,这将允许您轻松切换不同的日志框架.
因此,在使用SLF4J Facade时,您在代码中使用的所有日志记录调用都将委派给底层日志记录框架.
从插图中可以看出,您的应用SLF4J API每次都使用一个具有不同日志框架的通用API接口.
现在,让我们看看您的Gradle输出:
SLF4J: Class path contains multiple SLF4J bindings.
SLF4J: Found binding in [jar:file:/C:/Users/i/.gradle/caches/modules-
2/files-2.1/org.slf4j/slf4j-
log4j12/1.6.1/bd245d6746cdd4e6203e976e21d597a46f115802/slf4j-log4j12-
1.6.1.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Found binding in
[jar:file:/C:/Users/i/.gradle/caches/modules-2/files-
2.1/ch.qos.logback/logback-
classic/1.1.3/d90276fff414f06cb375f2057f6778cd63c6082f/logback-classic-
1.1.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 [org.slf4j.impl.Log4jLoggerFactory]
SLF4J: Detected both log4j-over-slf4j.jar AND slf4j-log4j12.jar on the class
path, preempting StackOverflowError.
Run Code Online (Sandbox Code Playgroud)
这是两个不同的SLF4J日志框架绑定的情况,第一个是org.slf4j/slf4j-log4j12,它是LOG4J日志框架绑定,第二个是ch.qos.logback/logback-classic,它是Logback日志框架, SLFJ API的原生实现.
因此,为了解决您的问题,您需要从类路径中排除其中一个.
具体来说,这里有问题的工件是org.apache.zookeeper:zookeeper:3.4.5让我们排除其中一个日志框架:
dependencies {
compile('org.apache.zookeeper:zookeeper:3.4.5') {
exclude group: 'ch.qos.logback', module: 'logback-classic'
}
//...
}
Run Code Online (Sandbox Code Playgroud)
参考:SLF4J手册
正如@Vampire 所说,这看起来像是类路径的问题buildscript,而不是compile或runtime配置的问题。它可能可以通过修复
buildscript {
configurations {
classpath {
exclude group: 'ch.qos.logback', module: 'logback-classic'
// OR
exclude group: 'org.slf4j', module: 'slf4j-log4j12'
}
}
dependencies { ... }
}
Run Code Online (Sandbox Code Playgroud)
您的依赖动物园也包含org.slf4j:slf4j-api依赖项。所以只需排除它
+--- org.apache.zookeeper:zookeeper:3.4.5
| +--- org.slf4j:slf4j-api:1.6.1 -> 1.7.21
| +--- org.slf4j:slf4j-log4j12:1.6.1
| | +--- org.slf4j:slf4j-api:1.6.1 -> 1.7.21 # <-- dependency includes slf4j-api
| | \--- log4j:log4j:1.2.16
| +--- log4j:log4j:1.2.15 -> 1.2.16
| +--- jline:jline:0.9.94
| | \--- junit:junit:3.8.1
| \--- org.jboss.netty:netty:3.2.2.Final
+--- org.apache.httpcomponents:httpcore:4.4.5 -> 4.4.6
+--- org.apache.httpcomponents:httpclient:4.5.3
| +--- org.apache.httpcomponents:httpcore:4.4.6
| +--- commons-logging:commons-logging:1.2
| \--- commons-codec:commons-codec:1.9
+--- commons-io:commons-io:2.5
+--- org.jdom:jdom2:2.0.5
+--- org.slf4j:slf4j-api:1.7.21 # <-- Also included as a first tier dependency
Run Code Online (Sandbox Code Playgroud)
您build.gradle只需将其从zookeeper库中排除即可。
dependencies {
compile('org.apache.zookeeper:zookeeper:3.4.5') {
// exclude transitive logging dependency from zookeeper
exclude group: 'org.slf4j'
// might need to exclude log4j, not sure?
exclude group: 'log4j', module: 'log4j'
}
// .. other dependencies
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
14717 次 |
| 最近记录: |