根据Datastax documentation for Cassandra:
“如果协调器无法写入足够多的副本来满足请求的一致性级别,则它将引发Unavailable Exception,并且不执行任何写入。”
这是否意味着在写入过程中,由写入更新的数据将不可用于读取请求?我的意思是可能4/5个节点已成功向协调器发送了SUCCESS,这意味着它们的数据已更新。但是第5个尚未完成。现在,如果有读取请求进入并转到这4个节点之一,它将一直显示旧数据,直到协调器从第5个节点收到确认并标记新数据有效为止。
答案 0 :(得分:2)
如果协调器在尝试写之前知道它不可能达到一致性,那么它将在执行写操作之前立即使请求失败。 (在给出的报价中对此进行了说明)
但是,如果协调器在尝试时认为有足够的节点可以达到其配置的一致性级别,它将开始向其对等方发送数据。如果对等方之一未返回成功,则请求将失败,并且您将进入一种状态,其中失败的节点具有旧数据,而通过的节点具有新数据。
如果收到读取请求,无论它是旧的还是新的,它都会显示在到达的节点上找到的数据。
让我们以您的榜样进行演示。
如果您有5个节点并且具有复制3。这将意味着这5个节点中的3个将具有您已发送的写入。但是,三个节点之一将故障返回给协调器。现在,如果您以一致性级别ALL阅读。您将读取所有三个节点,并且将始终获得新的写入(最新时间戳始终会获胜)。
但是,如果您读的一致性等级为ONE,则有1/3的机会会得到旧值。