什么是主从复制?

本文详细介绍了MySQL的主从复制机制,包括主从复制的基本原理,如master如何记录binlog,slave如何同步并执行这些日志。讨论了全同步和半同步复制两种模式,分析了它们在数据一致性和性能之间的权衡。同时,提到了异步复制可能导致的问题,如主库故障时的日志丢失风险。
摘要由CSDN通过智能技术生成

1、什么是主从复制

主从复制是指将主数据库的DDL和DML操作通过二进制日志传到从数据库上,然后在从数据库上对这些日志进行重新执行,从而使从数据库和主数据库的数据保持一致。

2、主从复制的原理

 

  1. master提交完事务后,写入binlog

  2. slave连接到master,获取binlog

  3. master创建dump线程,推送binglog到slave

  4. slave启动一个IO线程读取同步过来的master的binlog,记录到relay log中继日志中

  5. slave再开启一个sql线程读取relay log事件并在slave执行,完成同步

  6. slave记录自己的binglog

 

由于mysql默认的复制方式是异步的,主库把日志发送给从库后不关心从库是否已经处理,这样会产生一个问题就是假设主库挂了,从库处理失败了,这时候从库升为主库后,日志就丢失了。由此产生两个概念。

全同步复制

主库写入binlog后强制同步日志到从库,所有的从库都执行完成后才返回给客户端,但是很显然这个方式的话性能会受到严重影响。

半同步复制

和全同步不同的是,半同步复制的逻辑是这样,从库写入日志成功后返回ACK确认给主库,主库收到至少一个从库的确认就认为写操作完成。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值