一主多从,可以缓解读的压力,但是一旦主宕机了,就不能写了;所以我们可以采用双主双从架构
双主双重架构规划:
主master 3307 ---> 从slave 3309
主master 3308 ---> 从slave 3310
3307 <---> 3308 互为主从
2个写节点,每个写节点下又是2个读节点;
1、配置每一台MySQL服务器的配置文件my.cnf
3307
3308
3309
3310
2、与一主多从一样,所有主服务器配置文件加上binlog配置
3307
3308
3309
3310
log-bin=mysql-bin
server-id=实例的端口(server-id要唯一)
3、第一台主服务器3307的my.cnf文件增加如下配置:(Master 3307)
auto_increment_increment=2
auto_increment_offset=1
log-slave-updates
sync_binlog=1
4、第二台主服务器3308的my.cnf文件增加如下配置:(Master 3308)
auto_increment_increment=2
auto_increment_offset=2
log-slave-updates
sync_binlog=1
配置项说明auto_increment_increment,控制主键自增的自增步长,用于防止Master与Master之间复制出现重复自增字段值,通常auto_increment_increment=n,有多少台主服务器,n 就设置为多少;
auto_increment_offset=1设置自增起始值,这里设置为1,这样Master的auto_increment字段产生的数值是:1, 3, 5, 7, …等奇数ID
注意auto_increment_offset的设置,不同的master设置不应该一样,否则就容易引起主键冲突,比如master1的offset=1,则master2的offset=2,master3的offset=3
在双主模式中,log-slave-updates 配置项一定要配置,否则在master1(3307)上进行了更新数据,在master2(3308)和slave1(3309)上会更新,但是在slave2(3310)上不会更新
sync_binlog表示每几次事务提交,MySQL把binlog缓存刷进日志文件中,默认是0,最安全的是设置为1;