Mysql 主从复制-原理篇
2015-09-28 16:06
471 查看
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 复制的延迟。
上图是一个典型的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 复制的延迟。
相关文章推荐
- 101个MySQL开源数据库调试和优化技巧
- mysql 循环插入
- 5.5.xx MySQL 编译安装
- rsyslog+mysql+loganalyzer 环境搭建日志服务器
- mysql拼音转化
- 如何解决局域网内mysql数据库连接慢
- mysql带参存储过程小例子
- mysql 数据库操作
- mysql学习之配置及常见命令
- MySQL存储过程调试工具-dbForge Studio for MySQL
- mysql EXPLAIN--执行计划
- MySql集群搭建
- sails 与mysql的连接
- mysql 数据表读锁机制详解
- Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)
- mysql 触发器中操作 动态表名 的解决办法
- mysql 操作 指南
- MySql批量更新方法
- MySql批量更新方法
- mysql创建存储过程 定时调用