Ошибка подключения Apache Cassandra JDBC

Я хочу подключиться к cassandra 1.2.4 на удаленном сервере через jdbc.

 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

Также есть еще кое-что, что я заметил. стандартный порт для кассандры 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) в URL-адресе, я получаю это исключение.

    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

Я был бы признателен за вашу помощь.


person user2332500    schedule 29.04.2013    source источник
comment
босс попробуйте с клиентом драйвера datastax-java. Вы не получите большой поддержки с JDBC   -  person abhi    schedule 02.05.2013


Ответы (1)


Здесь происходит пара вещей.

Самая простая проблема для решения:

java.rmi.server.ExportException: порт уже используется: 7199; java.net.BindException: адрес уже используется

Хотя C* использует порт 9160 для экономии, он также использует порт 7199 для JMX. Исключение в основном означает, что что-то еще мешает C * использовать этот порт, мои деньги находятся на другом сервере cassandra.

Используйте монитор активности / менеджер вкусов, чтобы убедиться, что вы остановили все экземпляры cassandra, а затем попробуйте перезапустить сервер, и если в osx/linux использовать флаг -f для запуска сервера на переднем плане, это облегчает остановку!

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

Следующая проблема (не уверен, что это проблема или вы просто решили запутать строку подключения)

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

Это неверно, вам нужно указать IP-адрес в части <domain>. Например:

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

Также вы не можете использовать порт 7199, он необходим для JMX и должен быть свободным, если вы не измените конфигурацию в файле cassandra-env.sh.

Дайте мне знать, как вы поживаете.

person Lyuben Todorov    schedule 02.05.2013
comment
спасибо за Ваш ответ. да, я решил запутать строку подключения. Я попытаюсь перезапустить сервер и сообщу вам, решил ли он мою проблему. - person user2332500; 05.05.2013
comment
к сожалению перезапуск сервера не решил мою проблему - person user2332500; 05.05.2013
comment
похоже, что в фоновом режиме работает еще один сервер C *. Запустите монитор активности / диспетчер задач и попробуйте найти процесс и убить его, а затем попробуйте перезапустить сервер. - person Lyuben Todorov; 06.05.2013
comment
это то, что я сделал. Я убил запущенный экземпляр cassandra и запустил новый. проблема, которая сохраняется, является исключением при подключении: java.sql.SQLNonTransientConnectionException: org.apache.thrift.transport.TTransportException: java.net.ConnectException: соединение отклонено: соединение - person user2332500; 06.05.2013