网站建设知识
mysql高可用双主配置
2025-07-22 10:01  点击:0

1.环境配置 master A 192.168.0.109 master B 192.168.0.112

都已安装完毕mysql 版本为5.7.12 2.复制配置AB

server-id=1server-id=2

log-bin=mysql-master-binlog-bin=mysql-master-bin

binlog_format=rowbinlog_format=row

relay_log_recovery=1relay_log_recovery=1

log_slave_updates=1log_slave_updates=1

slave-skip-errors=allslave-skip-errors=all

auto-increment-offset=1auto-increment-offset=2

auto-increment-increment=2auto-increment-increment=2

gtid-mode=ongtid-mode=on

enforce-gtid-consistency=trueenforce-gtid-consistency=true

参数说明: binlog_format:二进制日志的格式,有row、statement和mixed几种类型。 relay_log_recovery:当slave从库宕机后,假如relay-log损坏了,导致一部分中继日志没有处理,则自动放弃所有未执行的relay-log,并且重新从master上获取日志,这样就保证了relay-log的完整性。 log_slave_updates:表示slave将复制事件写进自己的二进制日志。当设置log_slave_updates时,你可以让slave扮演其它slave的master。此时,slave把SQL线程执行的事件写进行自己的二进制日志(binary log),然后,它的slave可以获取这些事件并执行它,slave可以是其它slave的master,从而扩散master的更新。 slave-skip-errors:跳过主从复制出现的错误

auto-increment-offset:自增长字段从那个数开始,他的取值范围是1 .. 65535 auto-increment-increment:自增长字段每次递增的量,其默认值是1,取值范围是1 .. 65535 在主主同步配置时,需要将两台服务器的auto_increment_increment增长量都配置为2,而要把auto_increment_offset分别配置为1和2。这样才可以避免两台服务器同时做更新时自增长字段的值之间发生冲突。参考:dev.mysql/doc/refman/5.0/en/replication-options-master.html gtid-mode=on:启用gtid类型,基于事务复制,否则就是普通的复制架构database enforce-gtid-consistency=true:强制GTID的一致性 slave-parallel-type='logical_clock':基于组提交的并行复制方式,默认database 基于库的并行复制方式 slave-paralles-workers=4:设定从服务器的SQL线程数;0表示关闭多线程复制功能;值与你要复制的数据库数目相同即可; master-info-repository=TABLE :主服信息记录库=表/文件,多源复制需要配置 relay-log-info-repository=TABLE:中继日志信息记录库,多源复制需要配置 sync-master-info=1:同步主库信息

3.步骤 1)按照2中配置修改my.cnf文件,并重启数据库 可以通过如下命令查看: show master status \G 查看master信息 show variables like 'gtid%'; 查看gtid-mode开启状态 2)在master A上创建复制用户: >create user 'repltest'@'192.168.0.%' identified by 'abc123'; >grant replication slave on *.* to 'repltest'@'192.168.0.%'; 3)在master B建立change master复制信道 >change master to master_host='192.168.0.109', >master_user='repltest', >master_password='abc123', >MASTER_AUTO_POSITION=1; 启动复制 start slave 通过show slave status \G 查看slave状态

可以查看在master新增的复制用户也通过了过来。 4)在master A建立change master复制信道

>change master to master_host='192.168.0.112', >master_user='repltest', >master_password='abc123', >MASTER_AUTO_POSITION=1; 启动复制 start slave 4.测试同步复制 1)在master A创建数据库 和表 并插入数据 mysql> create database test_db; mysql> create table temp(id int primary key not null auto_increment,a int,b int,c int as (a*b)); mysql> insert into temp (a,b)values(1,2),(3,4),(5,6); 可以在master B查看数据正常同步。 2)在master B上insert数据也可以及时同步masterA;

配置了双主复制,A和B都可以读写,后续可以配置Keepalived实现双主热备。