- 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/
使用 CQRS 和事件存储,微服务之间的编排提供了最终一致性,其中一个微服务中的更改需要一点时间才能传播到其他相关的下游系统(基本上是其他微服务)。 如果数据非常关键以至于两个微服务都应该对数据具有强
我遇到了“强最终一致性”的概念。 它应该比“最终一致性”强但比“强一致性”弱吗?有人可以用适用的例子解释这三个概念之间的区别吗? http://en.wikipedia.org/wiki/Eventu
为什么 AWS 在 DynamoDB 中说“强一致性”而在 S3 中说“写后读一致性”?这两个意思是一样的吗? 最佳答案 这两个术语本质上是同一个东西,从某种意义上说,先读后写是一种强一致性。 值得注
我的经验表明...... ofy().consistency(Consistency.STRONG).load().type(this.getEntityClass()).count() ...插入后
我需要使用一些唯一且一致的ID来索引数据,我尝试使用NSManagedObject的objectID,但是对于同一实体,它的objectID不断变化,有人知道这是否不一致吗? 最佳答案 除非您没有保存
官方文档是否在某处谈论 CloudKit 一致性?根据我的测试,它似乎是最终一致的——在写入后立即读取记录可能有效,也可能无效(返回空结果): CKDatabase *database = [[CKC
我有一个 FaunaDB,我想将其作为文档存储进行交互。我有一个 api: 从 FaunaDB 读取整个文档 根据对 api 的输入任意改变该数据 写回变异的同时保证数据没有被变异 如果尝试写入时读取
如果我不需要一致的状态或“严格”原子性,我会尝试了解何时使用数据库事务。 我没有某些银行风格要求,需要减少一列来抵消其他地方的增加。 我确实有某种形式的原子性,但只是为了“易于使用”,我想知道这是否足
我有一个包含多个 InnoDB 表的数据库,我想从中读取数据,然后将数据转储为 XML 格式。这样的 XML 将表示一个对象及其所有相关对象。 我不希望在读取过程中执行任何 INSERT(SELECT
所以我有一个排行榜,我每天使用以下查询有效地获取每个用户的分数: SELECT DATE(a.time) as time, a.userid, SUM(activity_weight) as weig
我正在尝试检查两个数据库之间的数据加载结果。不幸的是,我只能直接访问一个数据库 (MySQL),管理 MSSQL 的公司可以通过 API 将其公开给我们。 我想做的是检查行集中某些列的一致性。最初,我
我的类经常有一些属性,而其他对象的属性依赖于这些属性。定义和访问它们的最佳方式是什么?一个最小的例子应该可以解释我的问题。 假设我有一个定义圆的类: class Circle: def __i
1 基本场景 比如你有 N 个 cache 服务器(后面简称 cache ),那么如何将一个对象 object 映射到 N 个 cache 上呢,你很可能会采用类似下面的通用方法计算 o
假设我有两个集合,每个集合的值彼此独立,但每个都相互关联。他们是 photos和 users .用户和照片之间是一对多的关系。 非规范化数据的示例: users: { "id": "AABC",
我在 UIView 上有一个 UIButton。我想以编程方式确定显示 View 时在按钮内显示哪个图像。我已经重写了 UIView 中的 drawRect 方法并使用 setImage 来显示所需的
这里consistent request in Mongo我找到了如何在 java 代码中处理一致的请求。 DB db...; db.requestStart(); try { db.reque
目前,我正在使用 scipy 库中的 basshopping 来查找优化目标函数的最佳 x(其中 x 总共由 4 个因子组成)。当我让它运行几次时,每次运行都会给出不同的结果。有没有办法使结果更加一致
我有一个使用 android:layout_weight 作为标题间距的应用程序,但是当我在不同的屏幕尺寸上查看该应用程序时,间距会发生变化(与下面的行数据不对齐)。 我有 5 个 header ,但
当我的教授说“变量 1 和变量 2 应该处于一致状态”时,他的意思是什么? “处于一致状态”是什么意思? 最佳答案 这个措辞我听起来不太熟悉,但也许这就是教授的意图。我认为他的意思是变量已经初始化了。
我有 3 张 table : 模块: id_module | name -------------------- 1 users 2 roles .
我是一名优秀的程序员,十分优秀!