Apache Cassandra JDBC连接错误

时间:2013-04-29 15:14:42

标签: database jdbc nosql cassandra cassandra-jdbc

我想通过jdbc连接到远程服务器上的cassandra 1.2.4。

 package cassandraclient;
 import java.sql.Connection;
 import java.sql.DriverManager;
 import java.sql.PreparedStatement;
 import java.sql.SQLException;
 import java.sql.Statement;
 import java.util.logging.Level;
 import java.util.logging.Logger;

 public class CassClient {
 public static void main(String[] args) {
     try {

         Class.forName("org.apache.cassandra.cql.jdbc.CassandraDriver");

         Connection con =  DriverManager.getConnection("jdbc:cassandra://<domain>:7199");

        String query = "CREATE KEYSPACE CassandraClientTest WITH REPLICATION = { 'class' : 'SimpleStrategy', 'replication_factor' : 1 };";
        Statement statement = con.createStatement();

        boolean success = statement.execute(query);
        System.out.println("created keyspace " + success);
        statement.close();

        con.close();

    } 
    catch (ClassNotFoundException ex) {
        ex.printStackTrace();
    }
    catch (SQLException ex) {
        ex.printStackTrace();
    }
 }
 }

当我尝试建立连接时,我得到以下异常。

    java.sql.SQLNonTransientConnectionException: org.apache.thrift.transport.TTransportException
        at org.apache.cassandra.cql.jdbc.CassandraConnection.<init>(CassandraConnection.java:156)
        at org.apache.cassandra.cql.jdbc.CassandraDriver.connect(CassandraDriver.java:92)
        at java.sql.DriverManager.getConnection(DriverManager.java:582)
        at java.sql.DriverManager.getConnection(DriverManager.java:207)
        at cassandraclient.CassClient.main(CassClient.java:17)
    Caused by: org.apache.thrift.transport.TTransportException
        at org.apache.thrift.transport.TIOStreamTransport.read(TIOStreamTransport.java:132)
        at org.apache.thrift.transport.TTransport.readAll(TTransport.java:84)
        at org.apache.thrift.transport.TFramedTransport.readFrame(TFramedTransport.java:129)
        at org.apache.thrift.transport.TFramedTransport.read(TFramedTransport.java:101)
        at org.apache.thrift.transport.TTransport.readAll(TTransport.java:84)
        at org.apache.thrift.protocol.TBinaryProtocol.readAll(TBinaryProtocol.java:378)
        at org.apache.thrift.protocol.TBinaryProtocol.readI32(TBinaryProtocol.java:297)
        at org.apache.thrift.protocol.TBinaryProtocol.readMessageBegin(TBinaryProtocol.java:204)
        at org.apache.thrift.TServiceClient.receiveBase(TServiceClient.java:69)
        at org.apache.cassandra.thrift.Cassandra$Client.recv_describe_cluster_name(Cassandra.java:1101)
        at org.apache.cassandra.thrift.Cassandra$Client.describe_cluster_name(Cassandra.java:1089)
        at org.apache.cassandra.cql.jdbc.CassandraConnection.<init>(CassandraConnection.java:125)
        ... 4 more

还有一些我注意到的东西。 cassandra的标准端口是9160,我没有指定另一个端口。但当我尝试再次启动cassandra时,它给了我以下异常。

    Error: Exception thrown by the agent : java.rmi.server.ExportException: Port already in use: 7199; nested exception is:
            java.net.BindException: Address already in use

这就是我使用端口7199的原因。 当我在网址中使用端口9160(和其他端口,如9161..2)时,我得到了这个例外。

    java.sql.SQLNonTransientConnectionException: org.apache.thrift.transport.TTransportException: java.net.ConnectException: Connection refused: connect
        at org.apache.cassandra.cql.jdbc.CassandraConnection.<init>(CassandraConnection.java:156)
        at org.apache.cassandra.cql.jdbc.CassandraDriver.connect(CassandraDriver.java:92)
        at java.sql.DriverManager.getConnection(DriverManager.java:582)
        at java.sql.DriverManager.getConnection(DriverManager.java:207)
        at cassandraclient.CassClient.main(CassClient.java:28)
    Caused by: org.apache.thrift.transport.TTransportException: java.net.ConnectException: Connection refused: connect
        at org.apache.thrift.transport.TSocket.open(TSocket.java:183)
        at org.apache.cassandra.cql.jdbc.CassandraConnection.<init>(CassandraConnection.java:123)
        ... 4 more
    Caused by: java.net.ConnectException: Connection refused: connect
        at java.net.PlainSocketImpl.socketConnect(Native Method)
        at java.net.PlainSocketImpl.doConnect(PlainSocketImpl.java:351)
        at java.net.PlainSocketImpl.connectToAddress(PlainSocketImpl.java:213)
        at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:200)
        at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:366)
        at java.net.Socket.connect(Socket.java:529)
        at org.apache.thrift.transport.TSocket.open(TSocket.java:178)
        ... 5 more

感谢您的帮助。

1 个答案:

答案 0 :(得分:0)

这里发生了一些事情。

最容易解决的问题:

  

java.rmi.server.ExportException:端口已在使用中:7199;   java.net.BindException:已在使用的地址

虽然C *使用端口9160进行节俭,但它也使用端口7199进行JMX。异常基本上意味着其他东西阻止C *使用该端口,我的钱在另一个cassandra服务器上。

使用活动监视器/ tast管理器确保已停止所有cassandra实例,然后尝试重新启动服务器,如果在osx / linux上使用-f标志在forground中启动服务器,这将使停止!

  Windows> cassandra.bat
OSX/Linux$ ./cassandra -f

下一个问题(我不确定这是否是一个问题,或者您只是决定对连接字符串进行模糊处理)

Connection con =  DriverManager.getConnection("jdbc:cassandra://<domain>:7199");

这是不正确的,您需要在<domain>部分指定IP地址。 E.g:

Connection con =  DriverManager.getConnection("jdbc:cassandra://127.0.0.1:9160");
Connection con =  DriverManager.getConnection("jdbc:cassandra://mycassndrahost:9160");

此外,您无法使用JMX所需的端口7199,除非您更改 cassandra-env.sh 文件中的配置,否则必须是免费的。

让我知道你是怎么过的。