cassandra:如何使用lb连接cassandra集群



我目前正在尝试在我们的生产环境中设置cassandra集群(4个节点和2个种子)。当我使用逗号分隔的主机名和端口进行连接时,它运行良好。

cluster = HFactory.getOrCreateCluster("Test Cluster", "host1:9160,host2:9160,host3:9160,host4:9160");

但是,当我在连接到各个节点的lb处配置集群名称,并在Hector节俭客户端中配置该名称时。但我得到了以下的结论,

cluster = HFactory.getOrCreateCluster("Test Cluster", "lbname");

严重:me.prettyprint.ector.api.exceptions.HectorException:所有主机池都已标记。重试负担推到客户端。

me.prettyprint.hector.api.exceptions.HectorException: All host pools marked down. Retry burden pushed out to client.
        at me.prettyprint.cassandra.connection.HConnectionManager.getClientFromLBPolicy(HConnectionManager.java:393)
        at me.prettyprint.cassandra.connection.HConnectionManager.operateWithFailover(HConnectionManager.java:249)
        at me.prettyprint.cassandra.service.AbstractCluster.describeKeyspace(AbstractCluster.java:199)
        at com.july.storage.cassandra.util.CassandraDBUtil.getDb(CassandraDBUtil.java:107)
        at com.july.storage.cassandra.util.CassandraDBUtil.hasTable(CassandraDBUtil.java:91)
        at com.july.storage.cassandra.action.CassandraHandler.getCall(CassandraHandler.java:65)
        at com.july.storage.service.StorageService.GET(StorageService.java:58)
        at com.july.storage.cassandra.action.CassandraHandler.main(CassandraHandler.java:571)

不要在Cassandra前面使用负载均衡器。让您的客户端连接到所有节点。负载均衡器将只是一个故障点,并增加不必要的延迟。

最新更新