- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如果我们比较多种类型的复制(Single-leader、Multi-leader 或 Leaderless),Single-leader 复制就有可能是 Linearizable。在我的理解中,线性化意味着一旦写入完成,所有后续读取都应返回该值,或稍后写入的值。或者换句话说,如果只有一个数据库,但没有更多,应该会有一个印象。所以我想,没有陈旧的读物。
PostgreSQL 在他的流式复制中,能够使用 synchronous_standby_names
使其所有副本同步。并且它还具有与 synchronous_commit
进行微调的能力选项,可以设置为 remote_apply
,所以领导者一直等到事务在备用服务器上重放(使其对查询可见)。在 documentation ,在谈到 remote_apply 选项的段落中,它指出这允许在具有因果一致性的简单情况下进行负载平衡。
几页后,它说this :
,,一些解决方案是同步的,这意味着在所有服务器都提交事务之前,不会认为数据修改事务已提交。这保证了故障转移不会丢失任何数据,并且无论查询哪个服务器,所有负载平衡的服务器都将返回一致的结果,
所以我很难理解可以保证什么,以及如果我们将读取查询负载平衡到只读副本会发生什么异常。仍然可以有过时的读取吗?当我查询不同的副本以获得不同的结果时,甚至在领导者发生后没有写入时会发生这种情况吗?我的印象是肯定的,但我不确定。
如果不是,PostgreSQL 如何防止过时读取?我没有找到任何关于它如何在引擎盖下完全工作的详细信息。它是使用两阶段提交,还是对其进行一些修改,还是使用其他算法来防止过时读取?
如果它不提供无过时读取的选项,有没有办法做到这一点?我看到,PgPool 必须选择对不超过定义阈值的副本进行负载平衡,但我不明白是否可以将其定义为对与领导者一致的副本进行负载平衡。
真正理解在 PostgreSQL 的完全同步复制中是否会发生异常,我真的很困惑。
我知道这样的设置存在可用性问题,但现在不必担心。
最佳答案
如果您将同步复制与 synchronous_commit = remote_apply
一起使用,您可以确定,一旦提交修改事务,您就会在备用数据库上看到修改后的数据。
同步复制不使用两阶段提交,主服务器先在本地提交,然后在COMMIT
之前简单地等待同步备用服务器的反馈。返回。所以以下是可能的:
COMMIT
之前看到主节点上修改后的数据返回,并且在数据传播到备用数据库之前。COMMIT
之前看到备用数据库上的修改数据。在主要返回上。COMMIT
之前的适当时刻在主服务器上中断返回,事务将仅在主 上提交.在服务器上发生提交和向客户端报告的时间之间总是有一个特定的时间窗口,但该窗口随着流式复制而显着增加。关于PostgreSQL 同步复制一致性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63700820/
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
我是一名优秀的程序员,十分优秀!