我目前无法使用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)
但是,我已在guava
中加入了pom.xml
人工制品,如下所示:
<!-- 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/
我错过了依赖吗?
答案 0 :(得分:0)
根据its POM,cassandra-driver-core
版本1.0.4使用的是Guava版本14.0.1,而不是版本15.0。我猜你正在看一个版本冲突。即使该版本差异不是此问题的原因,也可能导致其他问题。
您通常不需要在POM中包含传递依赖项,Maven会为您处理这些依赖项。或者您自己的代码是否使用Guava本身?
答案 1 :(得分:0)
根据这个问题的建议:no such method error: ImmutableList.copyOf()
我不得不排除google collection 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>