我现在正在API端点上执行负载测试,将数据保存到cassandra中。通常它运行良好,但是当我执行异步插入操作时,我在错误回调上得到以下消息:
public ArrayList MultipleId = new ArrayList();
我按以下方式执行批量插入:
ERROR:root:Query '<BatchStatement type=UNLOGGED, statements=382, consistency=ONE>' failed: errors={}, last_host=XXXXX
使用错误回调处理程序:
query_template = self.query_template(table, columns, values, ttl, insertion_timestamp)
statement = self.session.prepare(query_template)
statement.consistency_level = self.write_consistency_level
batch = BatchStatement(batch_type=BatchType.UNLOGGED, retry_policy=RetryPolicy.RETRY,
consistency_level=self.write_consistency_level)
for elem in list_of_dictionary:
values = [elem[key] for key in field_list]
batch.add(statement, values)
if async:
future = self.session.execute_async(batch, values)
future.add_errback(error_handler, batch)
else:
self.session.execute(batch, values)
有没有人有线索?
答案 0 :(得分:0)
所以我发现了这个问题。
OperationTimedOut
类型的客户端错误。你可以在这里找到它:
我建议在你的回调处理程序中另外记录异常的类型,如
def default_error_handler(exc, batch):
"""
Default callback function that is triggered when the cassandra async operation failed
:param exception:
"""
logging.error("Batch '%s' failed with exception '%s' of type '%s' ", batch, exc, type(exc))
我现在会尝试解决我们的问题!