- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如何在分布式系统上获得高频、一致的读/写?通常不确定如何概念化大型系统上的一致性。
用例:阻止用户在指定时间段内执行相同的操作。在滥用情况下,这可能是高频操作。
扩展问题:我将如何扩大此操作?像 Firestore 这样的系统如何在提供高可用性的同时提供一致性? Firestore 配额(例如每秒写入 1 个文档)告诉我们他们是如何构建系统的?
谢谢
最佳答案
GCP 的 Firestore uses the same technology作为 Cloud Spanner 以确保大规模的一致性。要了解有关 Cloud Spanner 及其 CAP 影响的更多信息,请查看 the introduction here :
In terms of CAP, Spanner claims to be both consistent and highly available despite operating over a wide area [...]. Does this mean that Spanner is a CA system as defined by CAP? [...] The purist answer is “no” because partitions can happen and in fact have happened at Google, and during some partitions, Spanner chooses C and forfeits A. It is technically a CP system. However, no system provides 100% availability, so the pragmatic question is whether or not Spanner delivers availability that is so high that most users don't worry about its outages.
因此,虽然从技术上来说是 CP 系统,但 Cloud Spanner(以及 Firestore)实际上是 CAP,因为它的“5 个或更多 9”可用性保证足够高大多数用户都会忽略中断。
How do systems like Firestore provide high-availability while also providing consistency?
首先,Google 为此类服务运行自己的专用全局网络,这意味着与依赖公共(public)网络相比,他们能够提供更强有力的保证。
其次,这些系统利用同步时钟来确保一致性。就 Google 而言,这可以归结为 TrueTime,这是一种全局同步、基于 GPS 和原子钟的时钟,即使对于发生在地球两端的交易也能提供强大的时间语义(7 毫秒的有限不确定性)。时钟可以用本地计算代替通信:节点 N 不需要询问另一个节点 M 某些属性是否成立,而是可以根据过去有关 M 的一些信息以及 N 时钟上的当前时间(Liskov91)来推断答案。 )。
Cloud Spanner depends on TrueTime to generate monotonically increasing timestamps. Cloud Spanner uses these timestamps in two ways. First, it uses them as proper timestamps for write transactions without the need for global communication. Second, it uses them as timestamps for strong reads, which enables strong reads to execute in one round of communication, even strong reads that span multiple servers. source
有关时钟如何帮助分布式系统设计的进一步理论,请参阅 Liskov's paper here 。有关 Cloud Spanner 的更多信息,我强烈推荐 the original Spanner paper 上的这些摘要以及the follow-up paper .
更新:好消息是您不需要原子钟、GPS 和专用全局网络来确保一致性和高可用性。受开源 Spanner 启发的 CockroachDB 实现了与其前身大致相同的目标,尽管它必须依赖更粗粒度和效率较低的同步,而不是 TrueTime 强大的时间确定性,如 this fantastic comparison 中所述。 :
A simple statement of the contrast between Spanner and CockroachDB would be: Spanner always waits on writes for a short interval, whereas CockroachDB sometimes waits on reads for a longer interval.
关于google-cloud-firestore - 了解分布式系统中的一致性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57307800/
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
我是一名优秀的程序员,十分优秀!