共计 2373 个字符,预计需要花费 6 分钟才能阅读完成。
这篇文章给大家介绍 MySQL 数据库中怎么实现多主复制,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
MySQL 管理每个复制通道,都是通过一个 Master_info 类 (sql/rpl_mi.h 中定义),start_slave/change_master /stop_slave/show_slave/end_slave 这些函数都需要传入一个 Master_info 指针,这就给我们改造多 Master 提 供了很大的便利,基本只需要为每个复制通道传入相应的 Master_info 即可。
除了找到函数入口,还需要让语法支持多主,否则 CHANGE MASTER TO 语句并不能支持多主。我修改了 sql_yacc.yy,支持如下语法:
CHANGE MASTER lsquo; 通道标识 rsquo; TO,START SLAVE lsquo; 通道标识 rsquo;,STOP SLAVE lsquo; 通道标识 rsquo;,SHOW SLAVE lsquo; 通道标识 rsquo; STATUS。
这样就可以支持多 Master 的语法了。
另一个问题是怎么保存多个通道的信息,默认单通道的情况下,用 master.info 存 Master 的信息,用 relay-log.info 存复制应用 的情况。所以存储文件的名称也要修改,我的方式是,master.info 和 relay-log.info 在末尾加上通道标识后缀,例如名为”plx”的 通道,会存成 master.info.plx 和 relay-log.info.plx。Relay Log 因为有序列,所以增加”- 通道标识”在序列前。
还有一个问题就是,操作命令都是用通道标识来确定一个通道,那么肯定需要持久化正在用的通道名称,以及建立通道后可以用通道名获取相应的 Master_info。于是我新建了一个 MASTER_INFO_INDEX 类 (在 sql/rpl_mi.h),里面包含一个通道标识和 Master_info 指针的对应 HASH 表,以及持久化需要的 IO_CACHE,通过 master.info.index 这个文件来存已有的通道标识。
命名实例如下:
双击代码全选
11-rw-rw mdash;- 1 mysql mysql 10 Feb 13 20:40 master.info.index-rw-rw mdash;- 1 mysql mysql 76 Feb 14 17:27 master.info.plx1 -rw-rw mdash;- 1 mysql mysql 71 Feb 14 17:27 master.info.plx2 -rw-rw mdash;- 1 mysql mysql 90 Feb 14 17:25 relay-log.info.plx1 -rw-rw mdash;- 1 mysql mysql 90 Feb 14 17:27 relay-log.info.plx2 -rw-rw mdash;- 1 mysql mysql 160 Feb 14 10:16 mysql-relay-bin-plx1.000011 -rw-rw mdash;- 1 mysql mysql 83765425 Feb 14 17:27 mysql-relay-bin-plx1.000012 -rw-rw mdash;- 1 mysql mysql 106 Feb 14 10:16 mysql-relay-bin-plx1.index-rw-rw mdash;- 1 mysql mysql 160 Feb 14 10:16 mysql-relay-bin-plx2.000014 -rw-rw mdash;- 1 mysql mysql 83455792 Feb 14 17:27 mysql-relay-bin-plx2.000015 -rw-rw mdash;- 1 mysql mysql 106 Feb 14 10:16 mysql-relay-bin-plx2.index
下载 Patch 在此:http://bugs.mysql.com/file.php?id=18020
有了多 Master 以后我们可以做什么呢? 下面给两个应用场景。
第一个是一备多的备份。因为我们采用的分库策略,使我们一个集群会有很多个实例,每个实例里面有几个 Schema,但是肯定不会重复。例如第一个实例是 1~3 号 Schema。第二个实例就是 4~6 号 Schema,所以 binlog 应用到一起并不会冲突数据。这是我们测试的在线备份方案。
第二个是跨机房的 HA。为了容灾或者加速,很多公司都采用在不同机房部署数据库的方式,所以就涉及到数据同步。为了保证每个机房产生的数据不冲突,一般 来说我们采用的是 auto_increment_increment,auto_increment_offset 这两个参数,可以控制步进。例如双 MAster,我们会配置主库是奇数序列的 ID,备库是偶数序列的 ID,这样切换时就算有少量 binlog 还未应用,也不会导致数据冲突。跨机房以后,例 如两个机房都有双 Master,两个机房之间数据又需要同步,以前需要借助第三方脚本或者程序,有了多 Master,按如下方式搭建,设置步进为 4,就可 以保证每个机房有双 MAster HA,机房之间数据又可以同步。
已知缺陷:
1. 我还没做 reset slave lsquo; 通道标识 rsquo; 命令,就是复制通道还不能重置,只能 CHANGE MASTER 来改,不是做不了,因为暂时我们没这个需求,等稳定了再考虑这个细节。
2. 数据冲突没有检测。这个是无法解决的,我只是简单的调用了启动 Slave 的函数来启动多个复制线程,binlog 取到本地应用,有数据冲突是不能事先检测 的,执行到了才会报出来,可以设置 skip-slave-error,对全局有效。其他复制相关的也是全局有效。
关于 MySQL 数据库中怎么实现多主复制就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。