带有Cassandra 1.2.1的DataStax Java驱动程序2.0.0-beta2:不支持的协议版本

时间:2013-10-16 16:20:02

标签: cassandra datastax-java-driver

我想知道com.datastax.cassandra:cassandra-driver-core:2.0.0-beta2是否可以与org.apache.cassandra一起使用:cassandra-all:1.2.1。我正在使用cassandra-maven-plugin:1.2.1-1(使用org.apache.cassandra:cassandra-all:1.2.1),添加

start_native_transport: true
native_transport_port: ${cassandra.nativePort}

yaml插件属性。我可以成功telnet到端口。

但是,当我尝试通过以下代码进行连接时,

// Ports.NATIVE has the same value as "${cassandra.nativePort}" above
Cluster cluster = Cluster.builder().addContactPoint("127.0.0.1")
    .withPort(Ports.NATIVE).build();
Session session = cluster.connect();

我得到以下异常:

com.datastax.driver.core.exceptions.NoHostAvailableException: All host(s) tried for query failed (tried: /127.0.0.1 (com.datastax.driver.core.ConnectionException: [/127.0.0.1] Unexpected error during transport initialization (com.datastax.driver.core.TransportException: [/127.0.0.1] Unexpected exception triggered (com.datastax.driver.core.exceptions.DriverInternalError: Server response from unsupported protocol version: 1))))
    at com.datastax.driver.core.ControlConnection.reconnectInternal(ControlConnection.java:179)
    at com.datastax.driver.core.ControlConnection.connect(ControlConnection.java:77)
    at com.datastax.driver.core.Cluster$Manager.init(Cluster.java:868)
    at com.datastax.driver.core.Cluster$Manager.newSession(Cluster.java:888)
    at com.datastax.driver.core.Cluster$Manager.access$200(Cluster.java:792)
    at com.datastax.driver.core.Cluster.connect(Cluster.java:155)

我认为它的关键是Server response from unsupported protocol version: 1

这是否意味着2.0.0-beta2驱动程序不能与Cassandra 1.2.1一起使用?驱动程序/服务器兼容性矩阵在哪里?

我已经烧了差不多一天了。

谢谢, 马修

2 个答案:

答案 0 :(得分:12)

是的,这是不相容的。 From the java-driver 2.0 requirements

  

驱动程序使用Casandra的本机协议,此版本2.0使用该协议的第二个版本。因此,此版本的驱动程序需要Cassandra的版本大于或等于2.0(对于Cassandra 1.2,请使用驱动程序的1.0版本。)

尝试降级到1.0,最新版本是1.0.4:

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

答案 1 :(得分:-1)

驱动程序版本2.0或更高版本的默认协议级别为2.要使用旧版本的Cassandra(例如1.2),协议级别需要设置为1.

可以使用Cluster.withProtocolVersion方法(如

)在较新的驱动程序上设置协议版本

Cluster cluster = Cluster.builder()。addContactPoint(“127.0.0.1”)。withProtocolVersion(1)     .withPort(Ports.NATIVE).build();