All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.datastax.driver.core.DataCentersFinder Maven / Gradle / Ivy

Go to download

A driver for DataStax Enterprise (DSE) and Apache Cassandra 1.2+ clusters that works exclusively with the Cassandra Query Language version 3 (CQL3) and Cassandra's binary protocol, supporting DSE-specific features such as geospatial types, DSE Graph and DSE authentication.

There is a newer version: 2.4.0
Show newest version
/*
 * Copyright DataStax, Inc.
 *
 * This software can be used solely with DataStax Enterprise. Please consult the license at
 * http://www.datastax.com/terms/datastax-dse-driver-license-terms
 */
package com.datastax.driver.core;

import java.util.HashSet;
import java.util.Set;

class DataCentersFinder {
  Set getDataCenters(Cluster cluster) {
    int remoteConnectionsLength =
        cluster
            .getConfiguration()
            .getPoolingOptions()
            .getCoreConnectionsPerHost(HostDistance.REMOTE);
    Set dataCenters = new HashSet();

    for (Host h : cluster.getMetadata().getAllHosts()) {

      HostDistance distance =
          cluster.getConfiguration().getPolicies().getLoadBalancingPolicy().distance(h);
      if (distance.equals(HostDistance.LOCAL)
          || (distance.equals(HostDistance.REMOTE) && remoteConnectionsLength > 0)) {
        dataCenters.add(h.getDatacenter());
      }
    }
    return dataCenters;
  }

  String getLocalDataCenter(Cluster cluster) {
    for (Host h : cluster.getMetadata().getAllHosts()) {
      HostDistance distance =
          cluster.getConfiguration().getPolicies().getLoadBalancingPolicy().distance(h);
      if (distance.equals(HostDistance.LOCAL)) {
        return h.getDatacenter();
      }
    }
    return null;
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy