Mysql 主从复制-原理篇

     Mysql 自带的主从复制机制是十分强大的,通过配置,将Master中mysql的变化同步到slave数据库中,从而实现数据,表结构以及配置(DDL和DML)的同步。在复制过程中,Master负责将更新写入二进制文件中,并维护一个文件的索引,以跟踪日志循环,当一个从服务器连接到主服务器时,主服务器会通知从服务器在日志中最后一个成功更新的位置,从服务器接受从那时的任何更新,完成后封锁并等待主服务器通知新的更新。

上图是一个典型的Mysql master-slave 示意图。该图可以分为以下步骤:

1.Master将事务串行的写入二进制文件中,在事务写入binlog完成后,master通知存储引擎提交事务。

2.slave开启一个IO线程,IO线程在master上开启一个普通的连接,然后开始binlog dump process。

3.binlog dump process 从master上拉取binlog日志。

4.slave将master的binlog写入自己的中继日志中。

5.slave开启SQL thread,SQL thread从中继日志中读取Event,并将其回放在slave的Mysql中。


上如解决方案依赖于数据库的事务性,所以必须是串行执行的,阿里的Otter改进了这一方案,大大减小了Mysql 复制的延迟。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值