- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
您能否解释一下为什么即使使用基于法定人数的读写,Cassandra 也不能线性化?
线性度定义为
If operation B started after operation A successfully completed, then operation B must see the system in the same state as it was on completion of operation A, or a newer state.
最佳答案
编辑考虑 Cassandra 前景读取修复:
由于仅更新了部分副本集而导致的写入失败可能会导致两个不同的读者看到两个不同的数据值。这是因为在简单的基于群体的一致性方法中缺少回滚。此行为破坏了单键读取的线性化保证。如本 discussion 中所述,Raft 或 Paxos 等分布式共识协议(protocol)是此类保证的必备条件。
还有其他现象,例如 clock drift和 leap second可以破坏 Cassandra session 的一致性。
较早的回答(不考虑 Cassandra 前台读取修复):
总结:在 Cassandra 中,写可能感觉不到原子性。有些节点的写入速度比其他节点快,因此即使我们依赖仲裁,结果也取决于返回值的节点集以及它们在该点持有的值。
此外,为了解释添加到粗体定义中的线性化的定义
If operation B started after operation A successfully completed, thenoperation B must see the system in the same state as it was oncompletion of operation A, or a newer state (but never old state again) .
从 Martin Klepmann 的数据密集型应用程序一书中复制
线性化和群体直觉上,似乎严格的法定人数读写在 Dynamo 风格的模型中应该是可线性化的。然而,当我们有可变的网络延迟时,可能会出现竞争条件,如图 9-6 所示。
在图 9-6 中,x 的初始值为 0,写入客户端通过将写入发送到所有三个副本(n = 3,w = 3)来将 x 更新为 1。同时,客户端 A 从两个节点 (r = 2) 的法定人数中读取并在其中一个节点上看到新值 1。同样在写入的同时,客户端 B 从两个节点的不同仲裁中读取,并从两个节点取回旧值 0。
满足法定人数条件 (w + r > n),但此执行仍然不可线性化:B 的请求在 A 的请求完成后开始,但 B 返回旧值,而 A 返回新值。 (这又是图 9-1 中爱丽丝和鲍勃的情况。)
有趣的是,有可能以降低性能为代价使 Dynamo 样式的仲裁可线性化:读取器必须同步执行读取修复(请参阅第 178 页的“读取修复和反熵”),然后再将结果返回给应用程序 [23 ],并且写入者必须在发送其写入之前读取法定数量的节点的最新状态 [24、25]。然而,由于性能损失 [26],Riak 不执行同步读取修复。 Cassandra 确实会等待读取修复完成仲裁读取 [27],但如果对同一键有多个并发写入,它会失去线性一致性,因为它使用了最后写入获胜的冲突解决方案。
而且,这种方式只能实现可线性化的读写操作;可线性化的比较和设置操作不能,因为它需要共识算法 [28]。
总而言之,最安全的假设是具有 Dynamo 式复制的无领导者系统不提供线性化。
关于线性化与序列化的更多解释:
关于database - 为什么在使用基于法定人数的读写时 Cassandra 不可线性化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56795239/
我是 python 的新手。我试图找到我的文本的频率分布。这是代码, import nltk nltk.download() import os os.getcwd() text_file=open(
我对安卓 fragment 感到困惑。我知道内存 fragment 但无法理解什么是 android fragment 问题。虽然我发现很多定义,比如 Android fragmentation re
尝试对 WordPress 进行 dockerise 我发现了这个场景: 2个数据卷容器,一个用于数据库(bbdd),另一个用于wordpress文件(wordpress): sudo docker
这个问题已经有答案了: From the server is there a way to know that my page is being loaded in an Iframe (1 个回答)
我正在玩小型服务器,试图对运行在其上的服务进行docker化。为简化起见,假设我必须主要处理:Wordpress和另一项服务。 在Docker集线器上有许多用于Wordpress的图像,但是它们似乎都
我想要发生的是,当帐户成功创建后,提交的表单应该消失,并且应该出现一条消息(取决于注册的状态)。 如果成功,他们应该会看到一个简单的“谢谢。请检查您的电子邮件。” 如果不是,那么他们应该会看到一条适当
就是这样,我需要为客户添加一个唯一标识符。通过 strip 元数据。这就是我现在完全构建它的方式,但是我只有最后一部分告诉我用户购买了哪个包。 我试着看这里: Plans to stripe 代码在这
我有一个类将执行一些复杂的操作,涉及像这样的一些计算: public class ComplexAction { public void someAction(String parameter
这个问题已经有答案了: maven add a local classes directory to module's classpath (1 个回答) 已关闭10 年前。 我有一些不应更改的旧 E
我使用 fragment 已经有一段时间了,但我经常遇到一个让我烦恼的问题。 fragment 有时会相互吸引。现在,我设法为此隔离了一个用例,它是这样的: Add fragment A(也使用 ad
我的 html 中有一个 ol 列表,上面有行条纹。看起来行条纹是从数字后面开始的。有没有办法让行条纹从数字开始? 我已经包含了正在发生的事情的片段 h4:nth-child(even) {
如何仅使用 css 将附加图像 html 化? 如果用纯 css 做不到,那我怎么能至少用一个图像来做 最佳答案 这不是真正的问题,而是您希望我们为您编写代码。我建议您搜索“css breadcrum
以下是 Joshua 的 Effective Java 的摘录: If you do synchronize your class internally, you can use various te
在这里工作时,我们有一个框向业务合作伙伴提供 XML 提要。对我们的提要的请求是通过指定查询字符串参数和值来定制的。其中一些参数是必需的,但很多不是。 例如,我们要求所有请求都指定一个 GUID 来标
我有 3 个缓冲区,其中包含在 32 位处理器上运行的 R、G、B 位数据。 我需要按以下方式组合三个字节: R[0] = 0b r1r2r3r4r5r6r7r8 G[0] = 0b g1g2g3g4
我最近发现了关于如何使用 History.js、jQuery 和 ScrollTo 通过 HTML5 History API 对网站进行 Ajax 化的要点:https://github.com/br
我们有一个 Spring Boot 应用程序,由于集成需要,它变得越来越复杂——比如在你这样做之后发送一封电子邮件,或者在你之后广播一条 jms 消息等等。在寻找一些更高级别的抽象时,我遇到了 apa
我正在尝试首次实施Google Pay。我面临如何指定gateway和gatewayMarchantId的挑战。 我所拥有的是google console帐户,不知道在哪里可以找到此信息。 priva
昨天下午 3 点左右,我为两个想要从一个 Azure 帐户转移到另一个帐户的网站设置了 awverify 记录。到当天结束时,Azure 仍然不允许我添加域,所以我赌了一把,将域和 www 子域重新指
我正在使用terms facet在elasticsearch服务器中获取顶级terms。现在,我的标签"indian-government"不被视为一个标签。将其视为"indian" "governm
我是一名优秀的程序员,十分优秀!