Datastax Cassandra SSL Connection от Java ошибка NoHostAvailableException - PullRequest
0 голосов
/ 02 марта 2020

Я прочитал и попробовал многие из предложенных решений этого вопроса, но он все еще не работает для меня. Я получаю следующее исключение:

Exception in thread "main" com.datastax.driver.core.exceptions.NoHostAvailableException: All host(s) tried for query failed (tried: /1.2.3.4:9042 (com.datastax.driver.core.exceptions.TransportException:[/1.2.3.4:9042] Channel has been closed))

Я обновил драйверы до последней версии. Cassandra.yaml конфигурации приведены ниже:

start_native_transport: true native_transport_port: 9042 rpc_address: 0.0.0.0

Я могу подключиться к узлу из Datastax DevCenter, но не из Java , Я не уверен, где может быть проблема.

Это код, который я использую в Java.

public class ClientToNodeConnection {

  public static Logger logger = 
LoggerFactory.getLogger(ClientToNodeConnection.class);

  public static void main(String[] args) {

    ClientToNodeConnection l = new ClientToNodeConnection();

    l.execute();
  }

  private void execute() {
    Cluster cluster;
    Session session;

    logger.info("Login into {}");

    cluster = getCluster("/client-keystore.jks", "keypass", "1.2.3.4");

    // Connect to the cluster and keyspace "ssl"
    session = cluster.newSession();

    session.execute(" CREATE KEYSPACE IF NOT EXISTS ssl WITH replication = {'class':'SimpleStrategy', 'replication_factor':1};");


    session.execute("use ssl;");
    session.execute("CREATE TABLE IF NOT EXISTS songs (title text, lyrics text, PRIMARY KEY (title))");

    // Insert one record into the users table
    session.execute("INSERT INTO songs (title, lyrics) VALUES ('Don''t believe the hype', 'Caught you lookin for the same thing It''s a new thing check out this I bring')");

    // Use select to get the user we just entered
    ResultSet results = session.execute("SELECT * FROM songs Limit 200;");
    for (Row row : results) {
      logger.info("*** data extracted ***");
      logger.info("{} - {}", row.getString("title"), row.getString("lyrics"));
    }

    session.close();

    // Clean up the connection by closing it
    cluster.close();
  }


  // This method is an example of loading a truststore from a resource, decoding it with its password.
  private Cluster getCluster(String trustStoreLocation, String trustStorePassword, String host) {
    Cluster cluster;
    SSLContext sslcontext = null;

    try {

      InputStream is = ClientToNode.class.getResourceAsStream(trustStoreLocation);
      KeyStore keystore = KeyStore.getInstance("jks");
      char[] pwd = trustStorePassword.toCharArray();
      keystore.load(is, pwd);

      TrustManagerFactory tmf = TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm());
      tmf.init(keystore);
      TrustManager[] tm = tmf.getTrustManagers();

      sslcontext = SSLContext.getInstance("TLS");
      sslcontext.init(null, tm, null);
    } catch (KeyStoreException kse) {
      logger.error(kse.getMessage(), kse);
    } catch (CertificateException e) {
      logger.error(e.getMessage(), e);
    } catch (NoSuchAlgorithmException e) {
      logger.error(e.getMessage(), e);
    } catch (KeyManagementException e) {
      logger.error(e.getMessage(), e);
    } catch (IOException e) {
      logger.error(e.getMessage(), e);
    }

    JdkSSLOptions sslOptions = JdkSSLOptions.builder()
      .withSSLContext(sslcontext)
      .build();

    cluster = Cluster.builder()
      .withClusterName("cassandra")
      .withCredentials("casss", "cass")
      .addContactPoint(host)
      .withPort(9042)
      .withProtocolVersion(ProtocolVersion.V3)
      .withSSL(sslOptions)
      .build();

    return cluster;
  }

}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...