MySQL主从同步过程以及全同步、半同步
MySQL主从同步
MySQL主从同步是一种常用的数据库复制技术,用于将一个MySQL数据库(主数据库)的数据变更同步到另一个MySQL数据库(从数据库)上。
这种复制技术可以实现数据备份、读写分离、容灾等功能。
主从同步的过程
1. 主库记录二进制日志(Binary Log)
主数据库将所有数据更改操作(如插入、更新、删除等)都记录在二进制日志中。
二进制日志包含了数据库的逻辑修改,以便在从库上重现这些操作。
2. 从库连接主库并请求同步
从数据库连接到主数据库,并请求开始同步过程。从库会询问主库,从哪个位置的二进制日志开始同步。
3. 主库发送二进制日志
主数据库根据从库的请求,将二进制日志的内容发送给从库。
4. 从库应用二进制日志
从数据库接收到主库发送的二进制日志后,从库会按照接收到的顺序逐条应用这些日志中的数据修改操作,使得从库的数据与主库保持同步。
5. 从库定期确认同步位置
从库在同步过程中会记录自己已经成功同步的位置,以便在发生断线或重新连接时,能供从上次同步的位置继续。
全同步和半同步
这两种同步方式指的是从库在复制数据时,主库和从库之间的数据一致性保障程序不同。
全同步(Fully Synchronous)
在全同步模式下,当事务在主库上提交时,主库会等待所有的从库都将日志写入它们的中继日志(Relay Log)并应用完成后,主库才会认为事务提交成功。
这确保了主从数据的完全一致性,但也导致主库的写入性能降低,因为主库需要等待从库的确认。
半同步(Semi-Synchronous)
半同步模式下,当事务在主库上提交时,主库只等待至少一个从库将日志写入它们的中继日志并应用完成后,主库就认为事务提交成功。这样可以提高主库的写入性能,但可能会导致主从数据稍有延迟,因为并非所有从库都已经同步完成。
注意
需要注意的是,全同步模式相对于半同步模式来说,数据的一致性更高,但性能代价也更大。具体选择哪种模式取决于对数据一致性和性能的需求权衡。
在关键业务场景下,可能更倾向于全同步模式,而在某些读写分离的场景下,可以考虑半同步模式。