C'est probablement une question répétée, mais je ne peux pas comprendre où est la collision de liaison. J'ai mon Spring Boot 1.2.6.RELEASE
service et j'obtiens cette erreur lorsque je l'exécute:
SLF4J: Class path contains multiple SLF4J bindings.
SLF4J: Found binding in [jar:file:/home/jscherman/.m2/repository/ch/qos/logback/logback-classic/1.1.3/logback-classic-1.1.3.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Found binding in [jar:file:/home/jscherman/.m2/repository/org/slf4j/slf4j-log4j12/1.7.12/slf4j-log4j12-1.7.12.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]
C'est le mvn dependency:tree
sortie
[INFO] com.myenterprise:product-manager:jar:0.0.1-SNAPSHOT
[INFO] +- com.myenterprise.product:myproject-api:jar:0.0.1-SNAPSHOT:compile
[INFO] +- com.myenterprise.product:myproject-core:jar:0.0.1-SNAPSHOT:compile
[INFO] +- org.springframework.boot:spring-boot-starter-web:jar:1.2.6.RELEASE:compile
[INFO] | +- org.springframework.boot:spring-boot-starter-Tomcat:jar:1.2.6.RELEASE:compile
[INFO] | | +- org.Apache.Tomcat.embed:Tomcat-embed-core:jar:8.0.26:compile
[INFO] | | +- org.Apache.Tomcat.embed:Tomcat-embed-el:jar:8.0.26:compile
[INFO] | | +- org.Apache.Tomcat.embed:Tomcat-embed-logging-juli:jar:8.0.26:compile
[INFO] | | \- org.Apache.Tomcat.embed:Tomcat-embed-websocket:jar:8.0.26:compile
[INFO] | +- com.fasterxml.jackson.core:jackson-databind:jar:2.4.6:compile
[INFO] | | +- com.fasterxml.jackson.core:jackson-annotations:jar:2.4.6:compile
[INFO] | | \- com.fasterxml.jackson.core:jackson-core:jar:2.4.6:compile
[INFO] | +- org.hibernate:hibernate-validator:jar:5.1.3.Final:compile
[INFO] | | +- javax.validation:validation-api:jar:1.1.0.Final:compile
[INFO] | | +- org.jboss.logging:jboss-logging:jar:3.1.3.GA:compile
[INFO] | | \- com.fasterxml:classmate:jar:1.0.0:compile
[INFO] | +- org.springframework:spring-core:jar:4.1.7.RELEASE:compile
[INFO] | +- org.springframework:spring-web:jar:4.1.7.RELEASE:compile
[INFO] | | \- org.springframework:spring-aop:jar:4.1.7.RELEASE:compile
[INFO] | \- org.springframework:spring-webmvc:jar:4.1.7.RELEASE:compile
[INFO] | \- org.springframework:spring-expression:jar:4.1.7.RELEASE:compile
[INFO] +- org.springframework.boot:spring-boot-starter-data-jpa:jar:1.2.6.RELEASE:compile
[INFO] | +- org.springframework.boot:spring-boot-starter-aop:jar:1.2.6.RELEASE:compile
[INFO] | | +- org.aspectj:aspectjrt:jar:1.8.6:compile
[INFO] | | \- org.aspectj:aspectjweaver:jar:1.8.6:compile
[INFO] | +- org.springframework.boot:spring-boot-starter-jdbc:jar:1.2.6.RELEASE:compile
[INFO] | | +- org.springframework:spring-jdbc:jar:4.1.7.RELEASE:compile
[INFO] | | +- org.Apache.Tomcat:tomcat-jdbc:jar:8.0.26:compile
[INFO] | | | \- org.Apache.Tomcat:tomcat-juli:jar:8.0.26:compile
[INFO] | | \- org.springframework:spring-tx:jar:4.1.7.RELEASE:compile
[INFO] | +- org.hibernate:hibernate-entitymanager:jar:4.3.11.Final:compile
[INFO] | | +- org.jboss.logging:jboss-logging-annotations:jar:1.2.0.Beta1:compile
[INFO] | | +- org.hibernate:hibernate-core:jar:4.3.11.Final:compile
[INFO] | | | +- antlr:antlr:jar:2.7.7:compile
[INFO] | | | \- org.jboss:jandex:jar:1.1.0.Final:compile
[INFO] | | +- dom4j:dom4j:jar:1.6.1:compile
[INFO] | | | \- xml-apis:xml-apis:jar:1.0.b2:compile
[INFO] | | +- org.hibernate.common:hibernate-commons-annotations:jar:4.0.5.Final:compile
[INFO] | | +- org.hibernate.javax.persistence:hibernate-jpa-2.1-api:jar:1.0.0.Final:compile
[INFO] | | \- org.javassist:javassist:jar:3.18.1-GA:compile
[INFO] | +- javax.transaction:javax.transaction-api:jar:1.2:compile
[INFO] | +- org.springframework:spring-orm:jar:4.1.7.RELEASE:compile
[INFO] | +- org.springframework.data:spring-data-jpa:jar:1.7.3.RELEASE:compile
[INFO] | | +- org.springframework.data:spring-data-commons:jar:1.9.3.RELEASE:compile
[INFO] | | \- org.slf4j:slf4j-api:jar:1.7.12:compile
[INFO] | \- org.springframework:spring-aspects:jar:4.1.7.RELEASE:compile
[INFO] +- mysql:mysql-connector-Java:jar:5.1.36:compile
[INFO] +- org.flywaydb:flyway-core:jar:3.1:compile
[INFO] +- org.springframework.security.oauth:spring-security-oauth2:jar:2.0.7.RELEASE:compile
[INFO] | +- org.springframework:spring-beans:jar:4.1.7.RELEASE:compile
[INFO] | +- org.springframework:spring-context:jar:4.1.7.RELEASE:compile
[INFO] | +- org.springframework.security:spring-security-core:jar:3.2.8.RELEASE:compile
[INFO] | | \- aopalliance:aopalliance:jar:1.0:compile
[INFO] | +- org.springframework.security:spring-security-config:jar:3.2.8.RELEASE:compile
[INFO] | +- org.springframework.security:spring-security-web:jar:3.2.8.RELEASE:compile
[INFO] | +- commons-codec:commons-codec:jar:1.6:compile
[INFO] | \- org.codehaus.jackson:jackson-mapper-asl:jar:1.9.13:compile
[INFO] | \- org.codehaus.jackson:jackson-core-asl:jar:1.9.13:compile
[INFO] +- org.springframework.boot:spring-boot-starter:jar:1.2.6.RELEASE:compile
[INFO] | +- org.springframework.boot:spring-boot:jar:1.2.6.RELEASE:compile
[INFO] | +- org.springframework.boot:spring-boot-autoconfigure:jar:1.2.6.RELEASE:compile
[INFO] | \- org.yaml:snakeyaml:jar:1.14:compile
[INFO] +- org.springframework.boot:spring-boot-starter-log4j:jar:1.2.6.RELEASE:compile
[INFO] | +- org.slf4j:jcl-over-slf4j:jar:1.7.12:compile
[INFO] | +- org.slf4j:jul-to-slf4j:jar:1.7.12:compile
[INFO] | +- org.slf4j:slf4j-log4j12:jar:1.7.12:compile
[INFO] | \- log4j:log4j:jar:1.2.17:compile
[INFO] \- org.springframework.boot:spring-boot-starter-test:jar:1.2.6.RELEASE:compile
[INFO] +- junit:junit:jar:4.12:compile
[INFO] +- org.mockito:mockito-core:jar:1.10.19:compile
[INFO] | \- org.objenesis:objenesis:jar:2.1:runtime
[INFO] +- org.hamcrest:hamcrest-core:jar:1.3:compile
[INFO] +- org.hamcrest:hamcrest-library:jar:1.3:compile
[INFO] \- org.springframework:spring-test:jar:4.1.7.RELEASE:compile
Donc, apparemment, le problème est que logback
est toujours dans classpath, mais je ne l'ai pas trouvé dans la sortie, donc je ne sais pas où est le problème.
Pouvez-vous repérer l'erreur? J'apprécierais votre aide
Cela ne se produit que lorsque j'exécute le serveur en tant qu'application Spring Boot. Si je l'exécute en tant que Java, l'erreur a disparu ... des idées?
J'ai eu exactement le même problème et je ne pouvais voir que la dépendance provenant de Spring Boot. Cela a également amené log4j-over-slf4j, ce qui était contraire à ma propre exigence de slf4j-log4j12. Résolu en ajoutant les exclusions ci-dessous. Ceci est plus spécifique que l'exclusion de la journalisation de démarrage de printemps.
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
<exclusions>
<exclusion>
<artifactId>logback-classic</artifactId>
<groupId>ch.qos.logback</groupId>
</exclusion>
<exclusion>
<artifactId>log4j-over-slf4j</artifactId>
<groupId>org.slf4j</groupId>
</exclusion>
</exclusions>
</dependency>
Supprimez la dépendance sur spring-boot-starter-log4j
qui apporte slf4j-log4j12
, Je pense que vous devriez utiliser use log4j-over-slf4j
si vous avez du code qui dépend de log4j. Voir ici pour une distinction.
Vous utilisez logback.xml sur votre chemin de classe et avez spring-boot-starter-log4j: jar sur votre pom c'est pourquoi le conflit pour lequel StaticLoggerBinder à utiliser.
SLF4J: Found binding in [jar:file:/home/jscherman/.m2/repository/ch/qos/logback/logback-classic/1.1.3/logback-classic-1.1.3.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Found binding in [jar:file:/home/jscherman/.m2/repository/org/slf4j/slf4j-log4j12/1.7.12/slf4j-log4j12-1.7.12.jar!/org/slf4j/impl/StaticLoggerBinder.class]
Veuillez supprimer l'une des bibliothèques de journalisation, par exemple spring-boot-starter-log4j de votre pom pour supprimer le conflit.
Étant donné que toutes les réponses précédentes n'ont pas réussi à faire fonctionner log4j2 (du moins pas pour moi), j'ai trouvé la solution sur https://docs.spring.io/spring-boot/docs/current/reference/ html/howto-logging.html # howto-configure-log4j-for-logging . Fondamentalement, excluez org.springframework.boot:spring-boot-starter-logging
de org.springframework.boot:spring-boot-starter
et ajouter org.springframework.boot:spring-boot-starter-log4j2
comme dépendance dans votre pom.xml
.
Cette erreur est due au fait qu'il existe plusieurs implémentations SLF4J dans le chemin de classe. SLF4J est une abstraction pour divers cadres de journalisation (tels que log4j ou logback), qui détecte l'implémentation pendant la phase de compilation par une méthode statique.
De votre dépendance: arbre, je ne trouve que log4j, il n'y a pas de pot lié à la logback
[INFO] +- org.springframework.boot:spring-boot-starter-log4j:jar:1.2.6.RELEASE:compile
[INFO] | +- org.slf4j:jcl-over-slf4j:jar:1.7.12:compile
[INFO] | +- org.slf4j:jul-to-slf4j:jar:1.7.12:compile
[INFO] | +- org.slf4j:slf4j-log4j12:jar:1.7.12:compile
[INFO] | \- log4j:log4j:jar:1.2.17:compile
Vous devez d'abord essayer d'exécuter maven - update project, puis le vérifier à nouveau.
Lorsque vous souhaitez utiliser log4j pour la journalisation et exclure l'implémentation de la journalisation par défaut, ajoutez cette dépendance si ce n'est déjà fait ou ajoutez la clause d'exclusion.
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
Voir Spring Logging - How To .