日期:2014-05-16  浏览次数:20700 次

Mysql主从同步架构图和原理
架构图



Replication原理   
Mysql 的 Replication 是一个异步的复制过程,从一个MySQL节点(称之为Master)复制到另一个MySQL节点(称之Slave)。在 Master 与 Slave 之间的实现整个复制过程主要由三个线程来完成,其中两个线程(SQL 线程和 I/O 线程)在 Slave 端,另外一个线程(I/O 线程)在 Master 端。 
  
要实现 MySQL 的 Replication ,首先必须打开 Master 端的 Binary Log,因为整个复制过程实际上就是 Slave 从 Master 端获取该日志然后再在自己身上完全顺序的执行日志中所记录的各种操作。 
  
看上去MySQL的Replication原理非常简单,总结一下: 
     * 每个从仅可以设置一个主。 
    * 主在执行sql之后,记录二进制log文件(bin-log)。 
    * 从连接主,并从主获取binlog,存于本地relay-log,并从上次记住的位置起执行sql,一旦遇到错误则停止同步。 
   
从这几条Replication原理来看,可以有这些推论: 
     * 主从间的数据库不是实时同步,就算网络连接正常,也存在瞬间,主从数据不一致。