NoClassDefFoundError - Cassandra 的 datastax java 驱动程序

Posted

技术标签:

【中文标题】NoClassDefFoundError - Cassandra 的 datastax java 驱动程序【英文标题】:NoClassDefFoundError - datastax java driver for Cassandra 【发布时间】:2013-11-04 12:56:07 【问题描述】:

我目前无法使用 datastax 驱动程序连接到我的 cassandra 数据库。我收到以下错误:

com.datastax.driver.core.TransportException: [/127.0.0.1] Unexpected exception triggered (java.lang.NoSuchMethodError: com.google.common.collect.ImmutableSet.copyOf(Ljava/util/Collection;)Lcom/google/common/collect/ImmutableSet;)
    at com.datastax.driver.core.Connection$Dispatcher.exceptionCaught(Connection.java:556)
    at org.jboss.netty.channel.SimpleChannelUpstreamHandler.handleUpstream(SimpleChannelUpstreamHandler.java:122)

Caused by: java.lang.NoSuchMethodError: com.google.common.collect.ImmutableSet.copyOf(Ljava/util/Collection;)Lcom/google/common/collect/ImmutableSet;
    at com.datastax.driver.core.DataType.<clinit>(DataType.java:144)
    at com.datastax.driver.core.Codec.<clinit>(Codec.java:31)

但是,我在pom.xml 中包含了guava 人工制品,如下所示:

<!-- Datastax driver -->

    <dependency>
        <groupId>com.datastax.cassandra</groupId>
        <artifactId>cassandra-driver-core</artifactId>
        <version>1.0.4</version>
    </dependency>

    <!-- Cassandra -->
    <dependency>
        <groupId>org.apache.cassandra</groupId>
        <artifactId>cassandra-all</artifactId>
        <version>1.2.9</version>
    </dependency>

    <!-- guava --<
    <dependency>
        <groupId>com.google.guava</groupId>
        <artifactId>guava</artifactId>
        <version>15.0</version>
    </dependency>

完整的pom.xml:http://pastebin.ubuntu.com/6358603/

我是否缺少依赖项?

【问题讨论】:

【参考方案1】:

根据its POM,cassandra-driver-core 的 1.0.4 版本使用 Guava 的 14.0.1 版本,而不是 15.0 版本。我猜你看到的是版本冲突。即使版本差异不是导致这个问题的原因,它也可能导致其他问题。

您通常不需要在 POM 中包含传递依赖项,Maven 会为您处理它们。还是您自己的代码使用 Guava 本身?

【讨论】:

【参考方案2】:

根据这个问题的建议:no such method error: ImmutableList.copyOf()

我不得不排除 google 收藏 jar:

    <dependency>
        <groupId>org.zkoss.zk</groupId>
        <artifactId>zkspring-core</artifactId>
        <version>3.1</version>
        <exclusions>
            <exclusion>
                <groupId>com.google.collections</groupId>
                <artifactId>google-collections</artifactId>
            </exclusion>
        </exclusions>
    </dependency>

【讨论】:

以上是关于NoClassDefFoundError - Cassandra 的 datastax java 驱动程序的主要内容,如果未能解决你的问题,请参考以下文章

NoClassDefFoundError

Androidx 迁移:NoClassDefFoundError

关于NoClassDefFoundError错误

毕业:java.lang.NoClassDefFoundError

Hive 安装问题:NoClassDefFoundError

NoClassDefFoundError:....KeyedObjectPoolFactory