gpt4 book ai didi

database - Apache Cassandra JDBC 连接错误

转载 作者:搜寻专家 更新时间:2023-10-30 20:57:19 27 4
gpt4 key购买 nike

我想通过 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 的原因。当我在 url 中使用端口 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

非常感谢您的帮助。

最佳答案

这里发生了一些事情。

最容易解决的问题:

java.rmi.server.ExportException: Port already in use: 7199; java.net.BindException: Address already in use

尽管 C* 将端口 9160 用于 thrift,但它也将端口 7199 用于 JMX。异常基本上意味着其他东西正在阻止 C* 使用该端口,我的钱在另一个 cassandra 服务器上。

使用事件监视器/测试管理器确保您已停止所有 cassandra 实例,然后尝试重新启动服务器,如果在 osx/linux 上使用 -f 标志在前台启动服务器,这使得它更容易停下!

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

下一个问题(我不确定这是一个问题还是你只是决定混淆连接字符串)

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

这不正确,您需要在 <domain> 中指定一个 IP 地址部分。例如:

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

此外,您不能使用端口 7199,JMX 需要它并且必须是免费的,除非您更改 cassandra-env.sh 文件中的配置。

让我知道你的进展情况。

关于database - Apache Cassandra JDBC 连接错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16282234/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com