- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想澄清 Cassandra 中复制因子和一致性级别的基本概念。如果有人能够回答以下问题,我们将不胜感激。
RF- 复制因子RC-读一致性WC- 写入一致性
2 个 cassandra 节点(例如:A、B)RF=1、RC=ONE、WC=ONE 或 ANY
3 个 cassandra 节点(例如:A、B、C)RF=2、RC=QUORUM、WC=QUORUM
3 个 cassandra 节点(例如:A、B、C)RF=3、RC=QUORUM、WC=QUORUM
最佳答案
简短摘要:复制因子描述了存在多少数据副本。一致性级别描述了客户端看到的行为。也许有更好的方法来对它们进行分类。
例如,您可以将复制因子设置为 2。当您写入时,假设有足够的节点已启动,则始终会存储两个副本。当一个节点关闭时,对该节点的写入会被隐藏起来,并在它恢复时写入,除非它关闭的时间足够长,以至于 Cassandra 认为它已经永远消失了。
现在假设在该示例中您使用一致性级别 ONE 进行编写。对一个节点进行写入操作后,客户端将收到成功确认,而无需等待第二次写入。如果您使用 CL 为 ALL 进行写入,则对客户端的确认将等到两个副本均写入后。还有很多其他一致性级别选项,太多而无法涵盖此处的所有变体。阅读Datastax doc不过,它很好地解释了它们。
在同一示例中,如果您以一致性级别 ONE 进行读取,则响应将在单个副本响应后发送到客户端。另一个副本可能有较新的数据,在这种情况下,响应将不是最新的。在许多情况下,这已经足够了。在其他情况下,客户端将需要最新的信息,并且您将在读取时使用不同的一致性级别 - 也许是 ALL 级别。这样,Cassandra 和其他后关系数据库的一致性就可以通过关系数据库通常无法调整的方式进行调整。
现在回到你的例子。
示例一:是的,您可以写入 A 并从 B 读取,即使 B 没有自己的副本。 B 将代表您的客户向 A 索取。对于节点全部启动的其他情况也是如此。当它们全部完成后,您可以向其中一个写入并从另一个读取。
对于写入,当 WC=ONE 时,如果单个副本的节点已启动并且是您要连接的节点,则写入将会成功。如果是其他节点,则写入会失败。如果您使用 ANY,写入将会成功,假设您正在与正在运行的节点通信。我认为您还必须为此启用暗示切换。关闭的节点稍后会获取数据,并且在此之后您将无法读取数据,甚至无法从运行的节点读取数据。
在其他两个示例中,复制因子将影响最终写入的副本数量,但不会影响我上面描述的客户端行为。 QUORUM 将影响客户端行为,因为您必须有足够数量的节点启动并响应写入和读取。如果幸运的话,您需要的节点中至少有 (nodes/2) + 1 个节点已启动,那么写入和读取就会成功。如果没有足够的节点来启动副本,则读取和写入将会失败。总体而言,如果某个节点发生故障,假设不需要该节点来存储副本,或者其中断仍然留下足够的副本节点可用,则某些 QUORUM 读取和写入可以成功。
关于cassandra - 了解 cassandra 复制因子与一致性级别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24587869/
GhostScript PDF/A 生成好像有错误 当您通过 GhostScript 生成 PDF/A 文档时,当您单击 Adobe Reader 时,会出现一个一致性选项卡,其中显示: “一致性
我有一个需要测试的 XPath 引擎实现。 是否有一组标准的一致性测试可以用来验证是否符合 XPath 规范(与 XSLT 相关)。 什么将是完美的 XML 文档 XPath 表达式和预期的结果。 最
帮助我了解在这种情况下我可以期望与 MongoDB 的一致性级别。 我们正在运行一个副本集,其中 Mongoid 中的 consistency 标志设置为 strong,这意味着只读到 master。
假设我有一个采用一个参数的方法。 此参数应满足以下要求: 'of type':方法需要知道参数属于特定类(或子类)。 'implements interface':方法需要知道参数实现了特定的接口(i
当协议(protocol)将属性声明为可选而具体类型将其声明为非可选时,如何使具体类型符合协议(protocol)? 这是问题所在: protocol Track { var trackNum
我正在考虑使用浏览器的 navigator.mimeTypes 数组作为第三级用户/浏览器标识符。例如,当我在 Chrome 上运行时... console.log(navigator.mimeTyp
我有以下协议(protocol): protocol ProtoAInput { func funcA() } protocol ProtoA { var input: ProtoAI
如果选择“最终”一致性,则发生写入的区域内的一致性是什么? 如果我只需要区域强一致性,应该选择哪个选项? 最佳答案 如果您需要在主要区域内进行强读取,则应该选择强一致性或有界过时一致性。 关于azur
您好,我是一名初学者,目前正在尝试学习 java 编程。课本上的问题: 编写一个程序来帮助人们决定是否购买混合动力汽车。你的程序的输入应该是:•新车的成本•预计每年行驶里程•预计汽油价格 •每加仑英里
我正在尝试制作一个可以在 UILabel 上使用的 Swift 协议(protocol), UITextField , 和 UITextView包含他们的text , attributedText ,
我有一个类扩展: extension UICollectionViewCell { class func registerFromNibInCollectionView(collectionV
为了在 Swift 中模拟对象进行测试,我通常遵循这样的模式:编写一个协议(protocol)来描述我想要的对象的行为,然后使用 Cuckoo 为其生成模拟以进行测试。 通常,这些协议(protoco
假设我有两个非通用协议(protocol)(1) protocol StringValue { var asString: String {get} } protocol StringProv
我有一组协议(protocol)可以在 UITableView 中显示一个元素: protocol TableRepresentableRow { var title: String { get
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topi
用“class”标记 CacheManager 解决了我的问题。 案例:一个简单的缓存器,mutating get 不是我想要的,那么对于引用类型或类类型应该怎么做? protocol Cacher
我想要一个符合协议(protocol)的变量,但是 swift 编译器告诉我协议(protocol)没有确认。 protocol A {} protocol B { var a : A { g
如果我有一个类 Christmas 和一个协议(protocol) Merry,要使 Christmas 符合 Merry,很多人会这样做: class Christmas { ... } e
@objc public protocol P1 { func p1foo() } @objc public protocol P2 { func p2foo() } class A: NSO
我有一些结构符合的基本协议(protocol)(模型)。它们也符合 Hashable protocol Model {} struct Contact: Model, Hashable { v
我是一名优秀的程序员,十分优秀!