无法完成对任何主机 cassandra 的操作
Unable to complete the operation against any hosts cassandra
我已经尝试过前面所述的解决方案here and here。我正在使用 datastax 的 cassandra-driver。我的 cassandra 版本是 2.2。8.I 已经在其中创建了键空间 CT_KEYSPACE
和 CT_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 .
我已经尝试过前面所述的解决方案here and here。我正在使用 datastax 的 cassandra-driver。我的 cassandra 版本是 2.2。8.I 已经在其中创建了键空间 CT_KEYSPACE
和 CT_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 .