无法完成对任何主机 cassandra 的操作

Unable to complete the operation against any hosts cassandra

我已经尝试过前面所述的解决方案here and here。我正在使用 datastax 的 cassandra-driver。我的 cassandra 版本是 2.2。8.I 已经在其中创建了键空间 CT_KEYSPACECT_TABLE。我通过 cqlsh 提示在 CT_TABLE 中插入了值。以下是 python 检索行

的代码
from cassandra.cluster import Cluster
cluster = Cluster()
session = cluster.connect('CT_KEYSPACE')
result = session.execute("select * from CT_TABLE")
print result.attribute, result.value

以下是 DESCRIBE CT_KEYSPACE 的输出:

cqlsh> describe ct_keyspace

CREATE KEYSPACE ct_keyspace WITH replication = {'class': 'SimpleStrategy', 'replication_factor': '1'}  AND durable_writes = true;

CREATE TABLE ct_keyspace.ct_table (
    attribute text PRIMARY KEY,
    value int
) WITH bloom_filter_fp_chance = 0.01
    AND caching = '{"keys":"ALL", "rows_per_partition":"NONE"}'
    AND comment = ''
    AND compaction = {'class': 'org.apache.cassandra.db.compaction.SizeTieredCompactionStrategy'}
    AND compression = {'sstable_compression': 'org.apache.cassandra.io.compress.LZ4Compressor'}
    AND dclocal_read_repair_chance = 0.1
    AND default_time_to_live = 0
    AND gc_grace_seconds = 864000
    AND max_index_interval = 2048
    AND memtable_flush_period_in_ms = 0
    AND min_index_interval = 128
    AND read_repair_chance = 0.0
    AND speculative_retry = '99.0PERCENTILE';

以下是我收到的错误:

Traceback (most recent call last):
  File "connection.py", line 4, in <module>
    result = session.execute("select * from CT_TABLE")
  File "/usr/local/lib/python2.7/dist-packages/cassandra/cluster.py", line 1998, in execute
    return self.execute_async(query, parameters, trace, custom_payload, timeout, execution_profile, paging_state).result()
  File "/usr/local/lib/python2.7/dist-packages/cassandra/cluster.py", line 3781, in result
    raise self._final_exception
cassandra.cluster.NoHostAvailable: ('Unable to complete the operation against any hosts', {})

非常感谢任何帮助。

发生这种情况是因为您在连接中提供了错误的键空间名称。使用 "ct_keyspace" 而不是 "CT_KEYSPACE"。您可能还记得 CQL 中不带引号的标识符不区分大小写(例如您的 select 语句)。但是,在参数传递的上下文中(如 Cluster.connect(<keyspace>)),文字不区分大小写。

如果您启用日志记录,您会看到驱动程序不断地无法在连接上设置该键空间。我创建了一个票证来改进这种情况下的错误处理:
https://datastax-oss.atlassian.net/browse/PYTHON-665

我遇到了同样的错误,经过一些检查我了解到我的磁盘驱动器已满 space 使用,我的服务器 OS 无法为 Cassandra 分配任何磁盘 space .