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

骑猪看日落 2023-10-14 02:29 80阅读 0赞

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

  • MySQL主从同步
  • 主从同步的过程
      1. 主库记录二进制日志(Binary Log)
      1. 从库连接主库并请求同步
      1. 主库发送二进制日志
      1. 从库应用二进制日志
      1. 从库定期确认同步位置
  • 全同步和半同步
    • 全同步(Fully Synchronous)
    • 半同步(Semi-Synchronous)
  • 注意

MySQL主从同步

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

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

主从同步的过程

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

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

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

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

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

3. 主库发送二进制日志

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

4. 从库应用二进制日志

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

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

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

全同步和半同步

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

全同步(Fully Synchronous)

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

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

半同步(Semi-Synchronous)

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

注意

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

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

发表评论

表情:
评论列表 (有 0 条评论,80人围观)

还没有评论,来说两句吧...

相关阅读

    相关 mysql 主从同步 + 同步 + GTID

    mysql主从同步复制定义 主从同步使得数据可以从一个数据库服务器复制到其他服务器上,在复制数据时,一个服务器充当主服务器(master),其余的服务器充当从服务器(sl