当然,5.6的GUID功能的出现也带来了multi-master的无限可能,不过这个已经是题外话了。
本文主要介绍一种非实时的适用于各版本MySQL的multi-master方法。
内容简介:
最初的思路来源于一位国外DBA的blog : http://thenoyes.com/littlenoise/?p=117
基本原理就是通过SP记录当前 master-log的name和pos记录到表中,然后读取下一个master记录,执行stop slave / change master / start slave。以此循环反复。
个人对他的方法进行了改进,增加了以下功能:
1. master可以根据业务流量设置权重值
2. 各个master-slave运行情况的监控
3. 各个master可以实时退出多主的架构
具体操作过程:
1. 创建保存各个master信息的表
新增加一个master :
手工把master 调整到当前的配置项:
创建rotate master SP:
注意:代码中用于连接master的用户名和密码是 : repl / repl ,请根据自己的情况修改。
创建Event:
每2分钟运行一次,rotate_master() ,即时间片大小是2分钟
至此,多主复制已经搭建完成。
由于时间片长度是2分钟。
Master1 在执行 1*2 分钟后,stop slave,然后change master to Master2;
Master2 在执行 2*2 分钟后,stop slave,然后change master to Master3;
Master3 在执行 5*2 分钟后,stop slave,然后change master to Master2;
并以此循环往复。
如果希望把其中一个master移除多主复制,可以将他的配置项权重设置为0;
即: update rotate_master set weigh=0 where id = #ID# ;