MySQL主从同步过程以及全同步、半同步

MySQL主从同步

MySQL主从同步是一种常用的数据库复制技术,用于将一个MySQL数据库(主数据库)的数据变更同步到另一个MySQL数据库(从数据库)上。

这种复制技术可以实现数据备份读写分离容灾等功能。

主从同步的过程

1. 主库记录二进制日志(Binary Log)

主数据库将所有数据更改操作(如插入、更新、删除等)都记录在二进制日志中。

二进制日志包含了数据库的逻辑修改,以便在从库上重现这些操作。

2. 从库连接主库并请求同步

从数据库连接到主数据库,并请求开始同步过程。从库会询问主库,从哪个位置的二进制日志开始同步

3. 主库发送二进制日志

主数据库根据从库的请求,将二进制日志的内容发送给从库。

4. 从库应用二进制日志

从数据库接收到主库发送的二进制日志后,从库会按照接收到的顺序逐条应用这些日志中的数据修改操作,使得从库的数据与主库保持同步。

5. 从库定期确认同步位置

从库在同步过程中会记录自己已经成功同步的位置,以便在发生断线或重新连接时,能供从上次同步的位置继续。

全同步和半同步

这两种同步方式指的是从库在复制数据时,主库和从库之间的数据一致性保障程序不同。

全同步(Fully Synchronous)

在全同步模式下,当事务在主库上提交时,主库会等待所有的从库都将日志写入它们的中继日志(Relay Log)并应用完成后,主库才会认为事务提交成功。

这确保了主从数据的完全一致性,但也导致主库的写入性能降低,因为主库需要等待从库的确认。

半同步(Semi-Synchronous)

半同步模式下,当事务在主库上提交时,主库只等待至少一个从库将日志写入它们的中继日志并应用完成后,主库就认为事务提交成功。这样可以提高主库的写入性能,但可能会导致主从数据稍有延迟,因为并非所有从库都已经同步完成。

注意

需要注意的是,全同步模式相对于半同步模式来说,数据的一致性更高,但性能代价也更大。具体选择哪种模式取决于对数据一致性和性能的需求权衡。

关键业务场景下,可能更倾向于全同步模式,而在某些读写分离的场景下,可以考虑半同步模式

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值