Chemin de classe contient de multiples SLF4J liaisons erreur
J'obtiens cette erreur quand tring pour exécuter gradle construire
je le comprends un versions conflit mais ne savez pas comment le résoudre, et qui
version à exclure...
gradle de l'arbre des dépendances est:
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 (*)
mais je ne sais même pas comment les lire...
pouvez vous nous aider s'il vous plaît ?
Le problème est lors de l'exécution de gradle, il ne peut pas être trouvé dans vos dépendances de l'application. S'il vous plaît montrer votre script de compilation(s).
OriginalL'auteur roman | 2017-02-20
Vous devez vous connecter pour publier un commentaire.
Tout d'abord, SLF4J est un simple façade pour l'enregistrement différents cadres (par exemple, java.util.la journalisation, logback, log4j) permettant à l'utilisateur final de brancher l'enregistrement souhaité cadre au moment du déploiement.
Que signifie en termes simples?
Lorsque vous utilisez SLF4J, votre code qui dépend d'une commune de la journalisation de l'interface qui vous est fournie par SLF4J (SLF4J-API), et de l'autre côté vous allez brancher la journalisation de votre choix pour SLF4J qui vous permettra de basculer d'enregistrement distinct des cadres facilement.
Donc, tous les journalisation des appels que vous utilisez dans votre code en utilisant le SLF4J façade sera déléguée à des sous-jacents de journalisation.
De l'illustration, vous pouvez voir que votre application utiliser une API commune interface
SLF4J API
avec différents journaux cadres à chaque fois.Maintenant, laissez-nous coup d'oeil sur votre Gradle de sortie:
C'est une situation de deux SLF4J de journalisation des liaisons, la première sur est org.slf4j/slf4j-log4j12 qui est LOG4J de journalisation de liaison, et le second est ch.la qualité de service.logback/logback-classique qui est le Logback de journalisation, le natif de mise en œuvre de SLFJ API.
Afin de résoudre votre problème, vous devez exclure l'un d'entre eux à partir de votre classpath.
Plus précisément ici, la problématique de l'artefact est
org.apache.zookeeper:zookeeper:3.4.5
donc, nous allons exclure l'une de l'enregistrement des cadres:Référence: SLF4J manuel
Ajout d'un exemple d'exclusion.
Vraiment merci pour l'effort accompli dans l'élaboration du problème lui-même, et en expliquant ce qui est slf4j et comment il fonctionne!
heureux de vous aider 🙂
OriginalL'auteur Stas
@Vampire dit, cela ressemble à un problème avec le buildscript classpath plutôt que de la
compile
ouruntime
configurations. Il pourrait probablement être fixé parOriginalL'auteur lance-java
Votre dépendance zoo contient également de la
org.slf4j:slf4j-api
de dépendance. Donc, juste l'exclureDans votre
build.gradle
juste de l'exclure de lazookeeper
lib.OriginalL'auteur JBirdVegas