- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我遇到了“强最终一致性”的概念。
它应该比“最终一致性”强但比“强一致性”弱吗?有人可以用适用的例子解释这三个概念之间的区别吗?
http://en.wikipedia.org/wiki/Eventual_consistency#Strong_Eventual_Consistency
http://en.wikipedia.org/wiki/Conflict-free_replicated_data_type
非常感谢。
最佳答案
免责声明:下面的文字应该让您大致了解最终一致性、强最终一致性和强一致性之间的区别。但在某种程度上,它们过于简单化了。所以把它们带上一粒盐 ;)
首先要做的事情是:当我们谈论一致性时,我们指的是不同实体(节点)拥有自己的某个数据对象副本的场景。现在,由于每个节点都可以更新自己的副本(例如,因为有客户端,每个客户端都连接到某个节点,要求它们这样做),因此会出现冲突,因此如果我从不同节点读取数据,我会看到不同的值。这就是最终一致性 (EC)、强最终一致性 (SEC) 和强一致性 (SC) 发挥作用的地方。
最终一致性
可能会出现冲突,但节点会相互传达他们的更改以解决这些冲突,因此他们会及时就最终值达成一致。因此,如果在一段时间内没有对数据应用更多更改,那么所有节点将在数据值上达成一致(即它们最终将达成一致),因此数据的读者最终将看到相同的值。
示例:两个节点 A 和 B(nA 和 nB)各有一个字符串副本,该字符串通过操作 read()
更新和 write(string)
.假设每个人都有自己的客户端(cliA 和 cliB)。假设最初两个节点存储相同的值“Joe”,但在某个时刻 nA 将其更新为“Frank”(调用 write("Frank")
)。然后nA会告诉nB值已经更新了;由于两个值不同,因此出现了冲突,但可以使用某些策略(例如最后写入获胜)来解决,因此 nB 最终也将其记录更新为“弗兰克”。在冲突解决之前,cliA 和 cliB 会看到不同版本的数据(read()
op 结果会有所不同),但最终两者都会再次看到相同的值。
请记住,如果两个节点同时更新它们的值,那么冲突解决仍然是可能的,但更复杂。这就是 SEC 大放异彩的地方。
强最终一致性
这是 EC 的一种特殊情况,仅对某些数据类型有效。
让我们假设共享的数据对象是一个计数器,并且更新是由 add(int value)
进行的。和 substract(int value)
操作。在这种情况下,我们应用更新的顺序无关紧要!因此,如果 nA 和 nB 都以计数器值 0 开始,然后 nA 运行 add(10)
和 nB 运行 substract(5)
(同时),它们只需要互相发送更新操作,而无需关心冲突解决,最终确保它们会达到相同的值(请记住,相比之下,在前面的 EC 示例中,一些冲突解决可能是必需的)!
不幸的是,SEC 仅适用于具有特定属性(可交换性和其他属性)的某些数据类型和操作。此类数据类型表示为 无冲突复制数据类型 (CRDT) .
强一致性
与其他两个完全不同。这里要求在更新操作时所有节点都同意新值,然后再使新值对客户端可见。这样,所有客户端都可以“同时”看到更新,因此它们将始终读取相同的值。现在这引入了对更新操作中的一些阻塞的要求。在 EC 和 SEC 中,更新操作在本地副本更新后立即结束(然后将操作广播到其他节点)。在这里,直到所有节点都同意数据值后,客户端更新才会返回,并且在完成此操作后,对该数据的任何副本的所有访问都被“锁定”(因此其他客户端读取被阻止)。在我们的 EC 示例中,如果 cliA 运行 write("Frank")
, cliA 将被阻塞,直到 nA 和 nB 都同意更新,然后它将同时对 cliA 和 cliB 可见,即 read()
从那时起,操作应该返回相同的值。
关于distributed-computing - "Eventual Consistency"对比 "Strong Eventual Consistency"对比 "Strong Consistency"?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29381442/
是否可以使用 boost::compute 复制自定义结构数组?例如 struct A { float a; }; struct AB { float a; float b; }; BOOST_COM
有谁知道如何在项目上配置的Google Cloud Networks之间移动现有的VM实例?我知道您可以在创建新VM时指定网络,但是似乎没有一种实例化它即可对其进行更改的功能。 任何指针表示赞赏! 保
我正在尝试遵循Google云平台控制台上的教程,以使用Compute Engine创建MongoDB应用程序。我遵循创建虚拟机的教程,但未创建它们,并返回以下错误: 字段“resource.netwo
我想知道是否可以将一个实例的类型更改为另一个实例,例如: n1-standard-1至n1-standard-2 我在文档中没有看到任何内容,但可能是我错过了一些东西。 如果这是不可能的,我该如何处理
我正在尝试让我的GCE实例监听多个IP地址(出于SEO的原因-在同一实例上托管多个低流量站点)。 最终目标:mydomain.com指向IP1,myotherdomain.es指向IP2,GCE实例将
使用scp,我可以添加-r标志以通过ssh将目录下载到本地计算机。 使用时: gcloud compute scp -r 它说“ -r”不是可用选项。 没有-r,我会收到一条错误消息,说我的源路径是一
仅某些IP地址的http负载均衡器存在严重问题。 我在这里还看到了其他一些帖子。我们确保防火墙正常,甚至删除并重新创建了转发规则。自IP更改以来,这非常令人讨厌。 仍然没有喜悦。问题仅影响某些IP地址
我正在尝试删除/删除不再使用的静态IP地址,并且看不到执行此操作的方法。我可以从文档中得到的最接近的是this page,它说: When an instance is stopped, you ca
我每天从台式计算机运行一个简单的任务 3 次。它在下午 4 点、晚上 8 点和凌晨 1 点连接到某个网站,下载少量数据(小于 50mb),并将其存储在硬盘上。每天运行这一点很重要,所以我正在考虑将其转
我是一个关于在Google Compute Engine上联网的问题。 是否可以在您的帐户上设置默认的“源代码/ IP范围”,以便在创建新规则时自动设置此值? 例如,如果我创建此规则: gcloud
我正在尝试使用 POST gcloud CLI 创建一个“带有容器”的 GCE 实例(由 https://www.googleapis.com/compute/v1/projects/{project
我们像这样通过命令行创建实例: gcloud compute instances create instance-name [--stuff otherstuff] --metadata-from-f
在我的本地 macOS 上,以下命令运行良好: $ gcloud source repos clone myrepo --project=myproject (虽然我不确定它是否有效,因为之前我遵循了
在 AWS SDK , EC2实例可以通过 AmazonEC2Client 以编程方式启动.是否GCP一般或Compute Engine特别just offer the CLI-based gclou
我想使用 SparkleShare 在计算机之间同步文件,所以我正在寻找一种方法让 git 存储库在线保存文件。 我正在考虑使用 Google Compute Engine 来托管它们。如果我只为我实
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 4年前关闭。 Improve thi
几周前,我在随意玩弄 Google Cloud Console,并创建了一个 Compute Engine VM。这个过程就像“创建一个虚拟机,命名它,保存”一样简单,就是这样。我现在不需要 Comp
我正在关注 this instruction在 GCE 上设置多个实例或服务器集群。它运行良好,但我不知道如何更新应用程序代码。例如,我有一些错误修复,需要更新代码并重新加载所有实例。无论如何我可以做
我在两个 VM 实例上有一个 node.js 应用程序,我试图通过网络负载平衡来进行负载平衡。为了测试我的服务器是否已启动并提供服务,我在我的应用程序内部监听端口上收到了运行状况检查请求“/healt
如何在GCE中永久设置实例的主机名?我可以通过主机名进行设置,但是重启后它又消失了。 我试图输入元数据(主机名:f.q.d.n),但这没有完成。但是它应该通过元数据(https://github.co
我是一名优秀的程序员,十分优秀!