Cassandra:在多个节点宕机的情况下提示切换

问题描述

Cassandra 使用暗示切换的概念来保​​证一致性。 这意味着如果一个节点宕机了,协调器会注意到它并等待它,然后重新向它发送写请求。

这是否意味着即使在等待不可用节点启动时,Cassandra 也会将成功响应发送回客户端?如果是,那么如果所有目标节点都关闭了怎么办?即使没有一次写入,是否也意味着对客户端的成功响应?

解决方法

如果无法实现一致性,则不会存储提示

例如,假设您有 3 个副本并且所有节点都已关闭。在这种情况下,如果写入一致性为 quorum,则不会存储提示并且写入将失败。只有当一个节点宕机并且协调器收到两个节点的成功响应时,才会存储提示。

唯一的例外是写一致性ANY。在这种情况下,即使所有副本都关闭,提示也会被存储并且写入会成功。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...