java - Dropwizard:java.lang.IllegalStateException:无法获取记录器上下文

标签 java maven logging slf4j dropwizard

我有一个项目,其中包含多个模块。其中一个模块,比如说“main”,有我的服务类“MyService.class”。 Dropwizard 有一个 jar - dropwizard-core。我想要这个 jar 在多个模块中,所以我想在父 POM 中保持它的依赖性。通过这样做,在运行我的 dropwizard 服务文件时,我遇到了如下异常:

SLF4J: Class path contains multiple SLF4J bindings.<br>
SLF4J: Found binding in [jar:file:/home/username/.m2/repository/org/slf4j/slf4j-simple/1.7.12/slf4j-simple-1.7.12.jar!/org/slf4j/impl/StaticLoggerBinder.class]<br>
SLF4J: Found binding in [jar:file:/home/username/.m2/repository/ch/qos/logback/logback-classic/1.1.3/logback-classic-1.1.3.jar!/org/slf4j/impl/StaticLoggerBinder.class]<br>
SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation.<br>
SLF4J: Actual binding is of type [org.slf4j.impl.SimpleLoggerFactory]<br><br>
Exception in thread "main" java.lang.IllegalStateException: Unable to acquire the logger context
                at io.dropwizard.logging.LoggingUtil.getLoggerContext(LoggingUtil.java:46)
                at io.dropwizard.logging.BootstrapLogging.bootstrap(BootstrapLogging.java:45)
                at io.dropwizard.logging.BootstrapLogging.bootstrap(BootstrapLogging.java:34)
                at io.dropwizard.Application.<init>(Application.java:24)
                at my.project.package.MyService.<init>(MyService.java:31)
                at my.project.package.MyService.main(MyService.java:38)

如果我将依赖项放在“主”模块的 POM 中,这个项目运行得非常好。

Dropwizard 与错误的记录器绑定(bind),这就是此异常背后的原因。但是这种绑定(bind)是在后台发生的,我无法控制它。

我还分享了这两种情况的依赖关系树。

情况 1:当 dropwizard-core 在子 POM(主模块)中时:

my.groupId.myProject:myProject-main:jar:1.0-SNAPSHOT<br>
[INFO] +- io.dropwizard:dropwizard-core:jar:0.9.2:compile<br>
[INFO] |  +- io.dropwizard:dropwizard-util:jar:0.9.2:compile<br>
[INFO] |  |  +- com.fasterxml.jackson.core:jackson-annotations:jar:2.6.0:compile<br>
[INFO] |  |  +- com.google.guava:guava:jar:18.0:compile<br>
[INFO] |  |  +- com.google.code.findbugs:jsr305:jar:3.0.1:compile<br>
[INFO] |  |  \- joda-time:joda-time:jar:2.9:compile<br>
[INFO] |  +- io.dropwizard:dropwizard-jackson:jar:0.9.2:compile<br>
[INFO] |  |  +- com.fasterxml.jackson.core:jackson-core:jar:2.6.3:compile<br>
[INFO] |  |  +- com.fasterxml.jackson.core:jackson-databind:jar:2.6.3:compile<br>
[INFO] |  |  +- com.fasterxml.jackson.datatype:jackson-datatype-jdk7:jar:2.6.3:compile<br>
[INFO] |  |  +- com.fasterxml.jackson.datatype:jackson-datatype-guava:jar:2.6.3:compile<br>
[INFO] |  |  +- com.fasterxml.jackson.module:jackson-module-afterburner:jar:2.6.3:compile<br>
[INFO] |  |  +- com.fasterxml.jackson.datatype:jackson-datatype-joda:jar:2.6.3:compile<br>
[INFO] |  |  +- org.slf4j:slf4j-api:jar:1.7.12:compile<br>
[INFO] |  |  \- ch.qos.logback:logback-classic:jar:1.1.3:compile<br>
[INFO] |  +- io.dropwizard:dropwizard-validation:jar:0.9.2:compile<br>
[INFO] |  |  +- org.hibernate:hibernate-validator:jar:5.2.2.Final:compile<br>
[INFO] |  |  |  +- javax.validation:validation-api:jar:1.1.0.Final:compile<br>
[INFO] |  |  |  +- org.jboss.logging:jboss-logging:jar:3.2.1.Final:compile<br>
[INFO] |  |  |  \- com.fasterxml:classmate:jar:1.1.0:compile<br>
[INFO] |  |  \- org.glassfish:javax.el:jar:3.0.0:compile<br>
[INFO] |  +- io.dropwizard:dropwizard-configuration:jar:0.9.2:compile<br>
[INFO] |  |  +- com.fasterxml.jackson.dataformat:jackson-dataformat-yaml:jar:2.6.3:compile<br>
[INFO] |  |  |  \- org.yaml:snakeyaml:jar:1.15:compile<br>
[INFO] |  |  \- org.apache.commons:commons-lang3:jar:3.4:compile<br>
[INFO] |  +- io.dropwizard:dropwizard-logging:jar:0.9.2:compile<br>
[INFO] |  |  +- io.dropwizard.metrics:metrics-logback:jar:3.1.2:compile<br>
[INFO] |  |  +- org.slf4j:jul-to-slf4j:jar:1.7.12:compile<br><br>
[INFO] |  |  +- ch.qos.logback:logback-core:jar:1.1.3:compile<br>
[INFO] |  |  +- org.slf4j:log4j-over-slf4j:jar:1.7.12:compile<br>
[INFO] |  |  +- org.slf4j:jcl-over-slf4j:jar:1.7.12:compile<br>
[INFO] |  |  \- org.eclipse.jetty:jetty-util:jar:9.2.13.v20150730:compile<br>
[INFO] |  +- io.dropwizard:dropwizard-metrics:jar:0.9.2:compile<br>
[INFO] |  +- io.dropwizard:dropwizard-jersey:jar:0.9.2:compile<br>
[INFO] |  |  +- org.glassfish.jersey.core:jersey-server:jar:2.22.1:compile<br>
[INFO] |  |  |  +- org.glassfish.jersey.core:jersey-common:jar:2.22.1:compile<br>
[INFO] |  |  |  |  +- org.glassfish.jersey.bundles.repackaged:jersey-guava:jar:2.22.1:compile<br>
[INFO] |  |  |  |  \- org.glassfish.hk2:osgi-resource-locator:jar:1.0.1:compile<br>
[INFO] |  |  |  +- javax.ws.rs:javax.ws.rs-api:jar:2.0.1:compile<br>
[INFO] |  |  |  +- org.glassfish.jersey.media:jersey-media-jaxb:jar:2.22.1:compile<br>
[INFO] |  |  |  +- javax.annotation:javax.annotation-api:jar:1.2:compile<br>
[INFO] |  |  |  +- org.glassfish.hk2:hk2-api:jar:2.4.0-b31:compile<br>
[INFO] |  |  |  |  +- org.glassfish.hk2:hk2-utils:jar:2.4.0-b31:compile<br>
[INFO] |  |  |  |  \- org.glassfish.hk2.external:aopalliance-repackaged:jar:2.4.0-b31:compile<br>
[INFO] |  |  |  +- org.glassfish.hk2.external:javax.inject:jar:2.4.0-b31:compile<br>
[INFO] |  |  |  \- org.glassfish.hk2:hk2-locator:jar:2.4.0-b31:compile<br>
[INFO] |  |  |     \- org.javassist:javassist:jar:3.18.1-GA:compile<br>
[INFO] |  |  +- org.glassfish.jersey.ext:jersey-metainf-services:jar:2.22.1:compile<br>
[INFO] |  |  +- org.glassfish.jersey.ext:jersey-bean-validation:jar:2.22.1:compile<br>
[INFO] |  |  +- io.dropwizard.metrics:metrics-jersey2:jar:3.1.2:compile<br>
[INFO] |  |  +- com.fasterxml.jackson.jaxrs:jackson-jaxrs-json-provider:jar:2.6.3:compile<br>
[INFO] |  |  |  +- com.fasterxml.jackson.jaxrs:jackson-jaxrs-base:jar:2.6.3:compile<br>
[INFO] |  |  |  \- com.fasterxml.jackson.module:jackson-module-jaxb-annotations:jar:2.6.3:compile<br>
[INFO] |  |  +- org.glassfish.jersey.containers:jersey-container-servlet:jar:2.22.1:compile<br>
[INFO] |  |  |  \- org.glassfish.jersey.containers:jersey-container-servlet-core:jar:2.22.1:compile<br>
[INFO] |  |  +- org.eclipse.jetty:jetty-server:jar:9.2.13.v20150730:compile<br>
[INFO] |  |  |  +- javax.servlet:javax.servlet-api:jar:3.1.0:compile<br>
[INFO] |  |  |  \- org.eclipse.jetty:jetty-io:jar:9.2.13.v20150730:compile<br>
[INFO] |  |  +- org.eclipse.jetty:jetty-webapp:jar:9.2.13.v20150730:compile<br>
[INFO] |  |  |  \- org.eclipse.jetty:jetty-xml:jar:9.2.13.v20150730:compile<br>
[INFO] |  |  \- org.eclipse.jetty:jetty-continuation:jar:9.2.13.v20150730:compile<br>
[INFO] |  +- io.dropwizard:dropwizard-servlets:jar:0.9.2:compile<br>
[INFO] |  |  \- io.dropwizard.metrics:metrics-annotation:jar:3.1.2:compile<br>
[INFO] |  +- io.dropwizard:dropwizard-jetty:jar:0.9.2:compile<br>
[INFO] |  |  +- io.dropwizard.metrics:metrics-jetty9:jar:3.1.2:compile<br>
[INFO] |  |  +- org.eclipse.jetty:jetty-servlet:jar:9.2.13.v20150730:compile<br>
[INFO] |  |  |  \- org.eclipse.jetty:jetty-security:jar:9.2.13.v20150730:compile<br>
[INFO] |  |  +- org.eclipse.jetty:jetty-servlets:jar:9.2.13.v20150730:compile<br>
[INFO] |  |  \- org.eclipse.jetty:jetty-http:jar:9.2.13.v20150730:compile<br>
[INFO] |  +- io.dropwizard:dropwizard-lifecycle:jar:0.9.2:compile<br>
[INFO] |  +- io.dropwizard.metrics:metrics-core:jar:3.1.2:compile<br>
[INFO] |  +- io.dropwizard.metrics:metrics-jvm:jar:3.1.2:compile<br>
[INFO] |  +- io.dropwizard.metrics:metrics-servlets:jar:3.1.2:compile<br>
[INFO] |  |  \- io.dropwizard.metrics:metrics-json:jar:3.1.2:compile<br>
[INFO] |  +- io.dropwizard.metrics:metrics-healthchecks:jar:3.1.2:compile<br>
[INFO] |  +- net.sourceforge.argparse4j:argparse4j:jar:0.6.0:compile<br>
[INFO] |  \- org.eclipse.jetty.toolchain.setuid:jetty-setuid-java:jar:1.0.3:compile<br>
[INFO] +- de.thomaskrille:dropwizard-template-config:jar:1.1.0:compile<br>
[INFO] +- my.groupId.myProject:myProject-module1:jar:1.0-SNAPSHOT:compile<br>
[INFO] +- my.groupId.myProject:myProject-module2:jar:1.0-SNAPSHOT:compile<br>
[INFO] +- my.groupId.myProject:myProject-module3:jar:0.0.1-SNAPSHOT:compile<br>
[INFO] |  +- io.dropwizard:dropwizard-auth:jar:0.9.1:compile<br>
[INFO] |  \- io.dropwizard:dropwizard-client:jar:0.9.1:compile<br>
[INFO] |     +- org.glassfish.jersey.core:jersey-client:jar:2.22.1:compile<br>
[INFO] |     +- org.apache.httpcomponents:httpclient:jar:4.5.1:compile<br>
[INFO] |     |  +- org.apache.httpcomponents:httpcore:jar:4.4.3:compile<br>
[INFO] |     |  \- commons-codec:commons-codec:jar:1.9:compile<br>
[INFO] |     +- io.dropwizard.metrics:metrics-httpclient:jar:3.1.2:compile<br>
[INFO] |     \- org.glassfish.jersey.connectors:jersey-apache-connector:jar:2.22.1:compile<br>
[INFO] +- junit:junit:jar:4.12:test<br>
[INFO] |  \- org.hamcrest:hamcrest-core:jar:1.3:test<br>
[INFO] +- org.hamcrest:hamcrest-library:jar:1.3:test<br>
[INFO] \- org.mockito:mockito-core:jar:1.10.19:test<br>
[INFO]    \- org.objenesis:objenesis:jar:2.1:test<br>

**Case 2 : When dropwizard-core is in parent POM :**

 my.groupId.myProject:myProject-main:jar:jar:1.0-SNAPSHOT<br>
[INFO] +- de.thomaskrille:dropwizard-template-config:jar:1.1.0:compile<br>
[INFO] +- my.groupId.myProject:myProject-module1:jar:1.0-SNAPSHOT:compile<br>
[INFO] +- my.groupId.myProject:myProject-module2:jar:1.0-SNAPSHOT:compile<br>
[INFO] +- my.groupId.myProject:myProject-common:jar:0.0.1-SNAPSHOT:compile<br>
[INFO] |  +- io.dropwizard:dropwizard-auth:jar:0.9.1:compile<br>
[INFO] |  \- io.dropwizard:dropwizard-client:jar:0.9.1:compile<br>
[INFO] |     +- org.glassfish.jersey.core:jersey-client:jar:2.22.1:compile<br>
[INFO] |     |  +- javax.ws.rs:javax.ws.rs-api:jar:2.0.1:compile<br>
[INFO] |     |  +- org.glassfish.jersey.core:jersey-common:jar:2.22.1:compile<br>
[INFO] |     |  |  +- org.glassfish.jersey.bundles.repackaged:jersey-guava:jar:2.22.1:compile<br>
[INFO] |     |  |  \- org.glassfish.hk2:osgi-resource-locator:jar:1.0.1:compile<br>
[INFO] |     |  +- org.glassfish.hk2:hk2-api:jar:2.4.0-b31:compile<br>
[INFO] |     |  |  +- org.glassfish.hk2:hk2-utils:jar:2.4.0-b31:compile<br>
[INFO] |     |  |  \- org.glassfish.hk2.external:aopalliance-repackaged:jar:2.4.0-b31:compile<br>
[INFO] |     |  +- org.glassfish.hk2.external:javax.inject:jar:2.4.0-b31:compile<br>
[INFO] |     |  \- org.glassfish.hk2:hk2-locator:jar:2.4.0-b31:compile<br>
[INFO] |     |     \- org.javassist:javassist:jar:3.18.1-GA:compile<br>
[INFO] |     +- org.apache.httpcomponents:httpclient:jar:4.5.1:compile<br>
[INFO] |     |  +- org.apache.httpcomponents:httpcore:jar:4.4.3:compile<br>
[INFO] |     |  \- commons-codec:commons-codec:jar:1.9:compile<br>
[INFO] |     +- io.dropwizard.metrics:metrics-httpclient:jar:3.1.2:compile<br>
[INFO] |     \- org.glassfish.jersey.connectors:jersey-apache-connector:jar:2.22.1:compile<br>
[INFO] +- io.dropwizard:dropwizard-core:jar:0.9.2:compile<br>
[INFO] |  +- io.dropwizard:dropwizard-util:jar:0.9.2:compile<br>
[INFO] |  |  +- com.fasterxml.jackson.core:jackson-annotations:jar:2.6.0:compile<br>
[INFO] |  |  +- com.google.guava:guava:jar:18.0:compile<br>
[INFO] |  |  +- com.google.code.findbugs:jsr305:jar:3.0.1:compile<br>
[INFO] |  |  \- joda-time:joda-time:jar:2.9:compile<br>
[INFO] |  +- io.dropwizard:dropwizard-jackson:jar:0.9.2:compile<br>
[INFO] |  |  +- com.fasterxml.jackson.core:jackson-core:jar:2.6.3:compile<br>
[INFO] |  |  +- com.fasterxml.jackson.core:jackson-databind:jar:2.6.3:compile<br>
[INFO] |  |  +- com.fasterxml.jackson.datatype:jackson-datatype-jdk7:jar:2.6.3:compile<br>
[INFO] |  |  +- com.fasterxml.jackson.datatype:jackson-datatype-guava:jar:2.6.3:compile<br>
[INFO] |  |  +- com.fasterxml.jackson.module:jackson-module-afterburner:jar:2.6.3:compile<br>
[INFO] |  |  +- com.fasterxml.jackson.datatype:jackson-datatype-joda:jar:2.6.3:compile<br>
[INFO] |  |  +- org.slf4j:slf4j-api:jar:1.7.12:compile<br>
[INFO] |  |  \- ch.qos.logback:logback-classic:jar:1.1.3:compile<br>
[INFO] |  +- io.dropwizard:dropwizard-validation:jar:0.9.2:compile<br>
[INFO] |  |  +- org.hibernate:hibernate-validator:jar:5.2.2.Final:compile<br>
[INFO] |  |  |  +- javax.validation:validation-api:jar:1.1.0.Final:compile<br>
[INFO] |  |  |  +- org.jboss.logging:jboss-logging:jar:3.2.1.Final:compile<br>
[INFO] |  |  |  \- com.fasterxml:classmate:jar:1.1.0:compile<br>
[INFO] |  |  \- org.glassfish:javax.el:jar:3.0.0:compile<br>
[INFO] |  +- io.dropwizard:dropwizard-configuration:jar:0.9.2:compile<br>
[INFO] |  |  +- com.fasterxml.jackson.dataformat:jackson-dataformat-yaml:jar:2.6.3:compile<br>
[INFO] |  |  |  \- org.yaml:snakeyaml:jar:1.15:compile<br>
[INFO] |  |  \- org.apache.commons:commons-lang3:jar:3.4:compile<br>
[INFO] |  +- io.dropwizard:dropwizard-logging:jar:0.9.2:compile<br>
[INFO] |  |  +- io.dropwizard.metrics:metrics-logback:jar:3.1.2:compile<br>
[INFO] |  |  +- org.slf4j:jul-to-slf4j:jar:1.7.12:compile<br>
[INFO] |  |  +- ch.qos.logback:logback-core:jar:1.1.3:compile<br>
[INFO] |  |  +- org.slf4j:log4j-over-slf4j:jar:1.7.12:compile<br>
[INFO] |  |  +- org.slf4j:jcl-over-slf4j:jar:1.7.12:compile<br>
[INFO] |  |  \- org.eclipse.jetty:jetty-util:jar:9.2.13.v20150730:compile<br>
[INFO] |  +- io.dropwizard:dropwizard-metrics:jar:0.9.2:compile<br>
[INFO] |  +- io.dropwizard:dropwizard-jersey:jar:0.9.2:compile<br>
[INFO] |  |  +- org.glassfish.jersey.core:jersey-server:jar:2.22.1:compile<br>
[INFO] |  |  |  +- org.glassfish.jersey.media:jersey-media-jaxb:jar:2.22.1:compile<br>
[INFO] |  |  |  \- javax.annotation:javax.annotation-api:jar:1.2:compile<br>
[INFO] |  |  +- org.glassfish.jersey.ext:jersey-metainf-services:jar:2.22.1:compile<br>
[INFO] |  |  +- org.glassfish.jersey.ext:jersey-bean-validation:jar:2.22.1:compile<br>
[INFO] |  |  +- io.dropwizard.metrics:metrics-jersey2:jar:3.1.2:compile<br>
[INFO] |  |  +- com.fasterxml.jackson.jaxrs:jackson-jaxrs-json-provider:jar:2.6.3:compile<br>
[INFO] |  |  |  +- com.fasterxml.jackson.jaxrs:jackson-jaxrs-base:jar:2.6.3:compile<br>
[INFO] |  |  |  \- com.fasterxml.jackson.module:jackson-module-jaxb-annotations:jar:2.6.3:compile<br>
[INFO] |  |  +- org.glassfish.jersey.containers:jersey-container-servlet:jar:2.22.1:compile<br>
[INFO] |  |  |  \- org.glassfish.jersey.containers:jersey-container-servlet-core:jar:2.22.1:compile<br>
[INFO] |  |  +- org.eclipse.jetty:jetty-server:jar:9.2.13.v20150730:compile<br>
[INFO] |  |  |  +- javax.servlet:javax.servlet-api:jar:3.1.0:compile<br>
[INFO] |  |  |  \- org.eclipse.jetty:jetty-io:jar:9.2.13.v20150730:compile<br>
[INFO] |  |  +- org.eclipse.jetty:jetty-webapp:jar:9.2.13.v20150730:compile<br>
[INFO] |  |  |  \- org.eclipse.jetty:jetty-xml:jar:9.2.13.v20150730:compile<br>
[INFO] |  |  \- org.eclipse.jetty:jetty-continuation:jar:9.2.13.v20150730:compile<br>
[INFO] |  +- io.dropwizard:dropwizard-servlets:jar:0.9.2:compile<br>
[INFO] |  |  \- io.dropwizard.metrics:metrics-annotation:jar:3.1.2:compile<br>
[INFO] |  +- io.dropwizard:dropwizard-jetty:jar:0.9.2:compile<br>
[INFO] |  |  +- io.dropwizard.metrics:metrics-jetty9:jar:3.1.2:compile<br>
[INFO] |  |  +- org.eclipse.jetty:jetty-servlet:jar:9.2.13.v20150730:compile<br>
[INFO] |  |  |  \- org.eclipse.jetty:jetty-security:jar:9.2.13.v20150730:compile<br>
[INFO] |  |  +- org.eclipse.jetty:jetty-servlets:jar:9.2.13.v20150730:compile<br>
[INFO] |  |  \- org.eclipse.jetty:jetty-http:jar:9.2.13.v20150730:compile<br>
[INFO] |  +- io.dropwizard:dropwizard-lifecycle:jar:0.9.2:compile<br>
[INFO] |  +- io.dropwizard.metrics:metrics-core:jar:3.1.2:compile<br>
[INFO] |  +- io.dropwizard.metrics:metrics-jvm:jar:3.1.2:compile<br>
[INFO] |  +- io.dropwizard.metrics:metrics-servlets:jar:3.1.2:compile<br>
[INFO] |  |  \- io.dropwizard.metrics:metrics-json:jar:3.1.2:compile<br>
[INFO] |  +- io.dropwizard.metrics:metrics-healthchecks:jar:3.1.2:compile<br>
[INFO] |  +- net.sourceforge.argparse4j:argparse4j:jar:0.6.0:compile<br>
[INFO] |  \- org.eclipse.jetty.toolchain.setuid:jetty-setuid-java:jar:1.0.3:compile<br>
[INFO] +- junit:junit:jar:4.12:test<br>
[INFO] |  \- org.hamcrest:hamcrest-core:jar:1.3:test<br>
[INFO] +- org.hamcrest:hamcrest-library:jar:1.3:test<br>
[INFO] \- org.mockito:mockito-core:jar:1.10.19:test<br>
[INFO]    \- org.objenesis:objenesis:jar:2.1:test<br>

如果有人能提出可能的推理,那将有很大帮助。

谢谢。

最佳答案

您的问题是您的类路径中有两个不同的 slf4j 实现(也称为绑定(bind)),情况不应该如此。

发生这种情况时,slf4j 使用第一个(按在类路径中出现的顺序)。然后dropwizard LoggingUtil尝试检索实际的 ILoggerFactory但期望它是 logback 的 LoggerContext 的一个实例.

在您的例子中,它是 SimpleLoggerFactory 的一个实例因为slf4j-simple当您声明对 dropwizard-core 的依赖项时,首先出现在类路径中在父 POM 中:确实是 logback-classic dropwizard-core 带来依赖.

解决方案非常简单:您必须删除对slf4j-simple 的依赖。 .

这在 slf4j manual 的最开头进行了解释.

关于java - Dropwizard:java.lang.IllegalStateException:无法获取记录器上下文,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36855953/

相关文章:

java - "argline"参数在 Maven Surefire Eclipse JUnit 中不起作用

vba - 'Open myFile For Append' 的日志记录策略(VBA Excel)

linux - 最佳鱿鱼日志文件分析工具

python - 解析大文本文件并提取数据而不循环多次 - Python

java - "T is a top-level class, and an assert statement lexically nested within T is executed."是什么意思?

java - 元素 'assert' 无效、放错位置或出现得太频繁

java - 缩短 CheckStyle 的控制台日志

java - 应用程序部署在 jboss 上,但当我尝试访问时出现 404 错误

java - 允许多于 1 个加密权限 itext

java - Eclipse - 无需鼠标即可通过超链接转到类/界面