- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
众所周知,mysql 是异步复制的。我听说我需要一些额外的插件来做
同步复制。
那么让我们考虑一下异步复制的情况:master 将事件写入其二进制日志,但不知道 master2 是否或何时检索并处理了它们。对于异步复制,如果 master1 崩溃,它提交的事务可能不会传输到任何 master2。
我的问题是,当master1再次启动时,这些事务是否最终会复制到master2?如果不是,那就是一个很大的不一致问题。
我的问题与主从复制相同,主服务器因相同情况而宕机。
我是否需要一些特殊的配置参数来使其自动发生?
或者我是否必须手动从 master1 中转出数据并导入到 master2 等?
======
更新:我可能用错了上面的“崩溃”这个词,我只想说master1在一段时间内无法同步数据给其他人的情况。下面的回复(感谢)包括两种情况:例如由于磁盘故障导致的真正无法恢复的崩溃,或者由于网络问题等导致的暂时离线问题。
最佳答案
如果 master1 在中断后重新上线,并且 binlog 没有丢失,那么副本可以下载它错过的任何 binlog。对于此讨论,master2 是副本。
当然,如果 master1 的崩溃严重到损坏或丢失其二进制日志,那你就倒霉了。
也有master1写入数据库更改但binlog条目在崩溃中丢失的情况。要解决此风险,您可以设置 sync_binlog=1
因此 master1 上的事务要求相应的 binlog 条目在磁盘上是安全的,否则事务无法完成。
但是在每次 COMMIT 时将 binlog 同步到磁盘会产生一些开销,并且许多站点决定他们宁愿拥有性能而不是数据安全。的确,某些工作负载每秒的事务处理率太高而不允许这样做。 IE。每秒磁盘同步数有一个物理上限。然后,解决方案需要获得更快的磁盘(或 SSD),或将工作负载分散到多台服务器上。
我也见过相反的情况:binlog 条目被写入 master1 上的文件系统缓存,副本下载该 binlog 条目并应用它,但该条目永远不会进入 master1 上的磁盘,因为磁盘有间歇性故障。具有讽刺意味的是,副本处理了从未提交到主磁盘上的磁盘的更改!
您提到了同步复制的可能性。 MySQL 并没有这个选项。他们最接近的是Semisynchronous Replication这意味着在至少一个半同步副本确认它已收到事务的二进制日志条目之前,master1 上的事务不允许提交。这意味着您永远不会出现上述差异。但这会为每个 COMMIT 增加一些延迟。
为什么是“半”同步?因为 master1 上的 COMMIT 不需要等待 replica 上的事务执行完毕,它只需要等待 replica 确认收到 binlog event。副本仍然可以落后。
@ceejayoz 的评论提到 Percona XtraDB Cluster .这与半同步复制非常相似,因为在 COMMIT 期间,写入器节点必须将该事务的日志传输到集群中的所有其他节点。所以延迟是最慢的节点确认接收事件的速度。
关于mysql master-master 数据复制一致性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21196000/
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
我是一名优秀的程序员,十分优秀!