Dropwizard 应用程序因 AbstractJAXBProvider 而崩溃

Dropwizard Application crashed by AbstractJAXBProvider

我有一个使用 Dropwizard and Gradle as Build System. Now I want to integrate Apache Mahout 实现的服务器应用程序用于某些推荐系统操作。

添加 Mahout 依赖项并尝试 运行 后,出现异常。

我的初始依赖项看起来像

dependencies {
    compile 'io.dropwizard:dropwizard-core:0.9.1'
    compile 'io.dropwizard:dropwizard-jdbi:0.9.1'
    compile 'mysql:mysql-connector-java:5.1.37'
    compile 'redis.clients:jedis:2.8.0'
    compile 'com.google.guava:guava:18.0'
    compile 'joda-time:joda-time:2.9.1'
    compile 'org.apache.commons:commons-math3:3.4.1'
}

为了做一些基本的推荐系统,我集成了依赖项

compile 'org.apache.mahout:mahout-mr:0.11.1'

当我现在 运行 应用程序时,我得到一个 NoClassDefFoundException:

WARN  [2015-12-07 15:03:09,696] org.glassfish.jersey.internal.Errors: 
The following warnings have been detected: WARNING: HK2 service reification 
failed for [com.sun.jersey.core.impl.provider.entity.MimeMultipartProvider] 
with an exception:
MultiException stack 1 of 2
java.lang.NoClassDefFoundError: javax/mail/internet/ParseException

所以我尝试通过

将这些东西集成为额外的依赖项
compile 'com.sun.mail:javax.mail:1.5.4'

运行 再次申请,我得到一个不同的异常:

WARN  [2015-12-07 15:05:02,161] org.glassfish.jersey.internal.Errors: The 
following warnings have been detected: WARNING: Unknown HK2 failure detected:
MultiException stack 1 of 2
java.lang.NullPointerException at 
com.sun.jersey.core.provider.jaxb.AbstractJAXBProvider.setConfiguration(AbstractJAXBProvider.java:109)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:606)

导致异常的代码来自Jersey:

@Context
public void setConfiguration(FeaturesAndProperties fp) {
    formattedOutput = fp.getFeature(FeaturesAndProperties.FEATURE_FORMATTED); // << Crash here
    xmlRootElementProcessing = fp.getFeature(FeaturesAndProperties.FEATURE_XMLROOTELEMENT_PROCESSING);
}

所以这里的功能似乎是空的,我们不能用它做任何事情。任何人都知道发生了什么,或者我该如何管理它?

问题是 Dropwizard 附带了 Jersey 依赖项(在我的例子中 org.glassfish.jersey in 2.22.x),而 Apache Mahout 附带了不同的 Jersey 依赖项(在我的例子中 com.sun.jersey 在 1.9).

所以排除 Mahout Jersey 依赖项就可以了。在我的例子中,这是由

完成的
compile('org.apache.mahout:mahout-integration:0.11.1') {
    exclude group: 'com.sun.jersey'
}

您正在使用的依赖项很可能有一个与您的模块不兼容的依赖项。

如果你用的是maven,用mvn dependency:tree搞清楚