- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
In the wikipedia article on CAP Theorem( https://en.wikipedia.org/wiki/CAP_theorem ), it states (bold emphasis mine) "When choosing consistency over availability, the system will return an error or a time-out if particular由于网络分区,无法保证信息是最新的。”
如果是这样,选择一致性而不是可用性是否意味着我们也失去了分区容错性?系统可能已启动,但如果它为我的所有数据访问返回错误,那有什么用呢?或者,“网络分区”在这里也意味着数据分区吗?换句话说,如果还隐含了数据分区,则至少已知部分数据是最新的并且可以返回,同时仍然满足一致性要求。
最佳答案
假设您有 2 个数据中心,每个数据中心都有一个单独的数据库,并且您的系统允许客户端连接到第一个或第二个数据中心。两个数据中心必须同步,因此它们之间存在网络链接。
现在假设网络链接中断,数据库之间无法再相互通信(这就是网络分区的意思)。作为应用程序开发人员,您现在做什么?
你基本上有两个选择:
1) 使系统可用,根据 CAP 定义,这意味着:
Every request received by a non-failing [database] node in the system must result in a [non-error] response
请注意,在我们的示例中,两个节点均未发生故障(它们已启动并正在运行)。
换句话说,你可以允许来自两个数据中心的所有客户端写入和读取数据,但你失去了一致性(见下面的定义),因为在一个数据库中的写入在另一个数据库中是不可见的。
2) 使系统保持一致(注意它与 ACID 一致性无关),按照 CAP 的定义,这意味着线性化,简单来说就是如果发生了写入,它必须被整个系统看到(既不是节点必须看到以前的状态)。
在我们的例子中,这意味着您需要拒绝来自其中一个数据中心的读写操作,因此只有一个数据中心可以运行。这样的系统根本不是无用的,并且您不会失去分区容错性,因为您可以将所有客户端重新路由到操作数据库。
围绕 CAP 定理存在很多混淆,我建议您阅读 Martin Kleppmann 的一篇优秀博客文章,它帮助我对这个主题有了很多了解: https://martin.kleppmann.com/2015/05/11/please-stop-calling-databases-cp-or-ap.html
关于distributed-system - CAP 定理中可用性的一致性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46597181/
使用这个通用元组类 public class Pair { private final T1 first; private final T2 second; public Pair(T1
我想不出执行此操作的递归算法。我的尝试是: void capValue(Node node) { if (node == null) return if (node.e
较新版本的 docker(我认为是 1.2 及更高版本)具有 --cap-add 功能。 这提供了对特性功能的细粒度控制,而无需使用 --privileged=true 打开所有内容。 我用谷歌搜索过
我开始使用 vim,我想重新映射一些键。有谁知道在 Lubuntu 中最简单的方法是什么。 谢谢 最佳答案 Caps Lock 键不能在 Vim 中映射,因为它不会自己生成键码。您可以在操作系统级别重
这是我的代码。 import java.util.stream.Stream; import java.util.List; import java.util.ArrayList; import ja
我想在 PyCharm 中使用 CapsLock-u 和 CapsLock-n 在代码和运行/终端之间切换。 在我的键盘上 u位于顶部,n在底部,这给了我一个很好的内存方法。 我不知道如何像这样配置我
我有一个值都是大写的对象,我想要 f.label帮助将其打印为全部大写 - 无需进行 CSS 转换。 现在,如果我有字符串 AAPL在我的对象中,f.label吐出来为 Aapl . 我不想使用 CS
我是电容器的新手,正在开发一个应用程序,我正在对代码进行更改并运行 ionic 构建 npx上限副本 npx盖帽开安卓 并且还推荐使用 npx cap sync代npx cap copy . 两者之间
print("Hello and welcome to your address book this program uses surnames or D.O.B to find people in
我在编写一些代码时遇到了一些让我烦恼的事情。我在下面的代码示例中收集了这两个示例。 cls1 行使用 lambda 表达式但不编译,而 cls2 行使用方法引用并编译。我知道如果我使用非泛型对象,我不
我一直在阅读有关名为Starcounter的数据库的信息。它声称可以处理“ NoSql”数据库只能处理的负载而不会降低一致性。据我了解CAP定理,如果保持一致性,则会失去可用性或分区容限。那么什么使S
分布式系统如何保持一致和可用-CA。因为当分区发生时,CA是不可能的。如果我们说不会发生分区,那么只有它们是CA,那么如果分区不会发生,那么所有CP或AP系统也将是CA。 最佳答案 不可以 如常提到的
我是 java 编程的初学者,并且在弄清楚如何限制代码中的金额时遇到问题。 我的代码有一个问题,该代码由 if-else if 语句组成,这更多的是如何限制奖金最高金额的问题。我希望我的奖金最高金额为
说到nosql分布式数据库系统,我们都知道它们都属于CAP定理的三取二。对于网络故障和节点故障不可避免的分布式集群,分区容忍是必要的,因此我们只能从可用性和一致性中选择一个。所以它基本上是 CP 或
python如何为视频制作一个简单的帽子。 Ideia:为 9 个均匀放置(在时间轴上)时间拍摄 9 个快照,然后在 JGP 中置换 我应该怎么做? PIL 是唯一的方法吗? (做我想做的事情并不容易
这个问题在这里已经有了答案: Is working past the end of a slice idiomatic? (2 个答案) 关闭 6 年前。 下面的go代码: var numbers4
我有一个 Silverlight 应用程序,它有两个不同的 XAP——一个由 HTML 页面静态加载的 InitialXAP 和一个从初始 XAP 中的代码加载的 DynamicXAP。 Dynami
In the wikipedia article on CAP Theorem( https://en.wikipedia.org/wiki/CAP_theorem ), it states (bol
在CAP定理中,Redis被指定为缺乏可用性(具有分区容错性和一致性)的数据库。 但是在很多地方,Redis 被认为是一种高可用的键值存储。 什么是对的?如果您能提供深入的答案,我将不胜感激。 最佳答
我被告知我必须放弃大型分布式系统中的事务保证,因为 CAP theorem说我不能拥有它。 我认为这是错误的,原因如下: 互联网路由非常可靠。 CAP 定理仅适用于两组事件机器无法通信的网络分区。 几
我是一名优秀的程序员,十分优秀!