CentOS8 在MySQL8.0 实现半同步复制
准备:设置 一个主节点10.0.0.8,两个从节点10.0.0.18和10.0.0.28
查看插件文件
[root@Centos8 ~]#rpm -ql mysql-server |grep semisync
/usr/lib64/mysql/plugin/semisync_master.so
/usr/lib64/mysql/plugin/semisync_slave.so
第一步,在10.0.0.8上 进入mysql
安装插件:
INSTALL PLUGIN rpl_semi_sync_master SONAME ‘semisync_master.so’;
配置文件 执行vim /etc/my.cnf
[mysqld]
server-id=8
log-bin
rpl_semi_sync_master_enabled=ON
rpl_semi_sync_master_timeout=3000
启动服务 systemctl restart mysqld
查看二进制 how master logs;
创建用户 create user repluser@'10.0.0.%'identified by ‘123456’;
授权 grant replication slave on . to repluser@‘10.0.0.%’;
在10.0.0.18和10.0.0.28上:
安装插件
两台主机都要安装:
INSTALL PLUGIN rpl_semi_sync_slave SONAME ‘semisync_slave.so’;
配置文件
10.0.0.18主机上配置
配置文件 vim /etc/my.cnf
[mysqld]
server-id=18
rpl_semi_sync_slave_enabled=ON
10.0.0.28主机上配置
[mysqld]
server-id=28
rpl_semi_sync_slave_enabled=ON
启动数据库 systemctl restart mysqld
启动服务
查看半同步变量 SHOW GLOBAL VARIABLES LIKE ‘%semi%’;
10.0.0.8主机已经开启
10.0.0.18和10.0.0.28也开启;
查看状态变量
还未开启SHOW GLOBAL STATUS LIKE ‘%semi%’;
10.0.0.8上显示还是0
第二步:设置主从
在18和28的主机设置;
CHANGE MASTER TO
MASTER_HOST=‘10.0.0.8’,
MASTER_USER=‘repluser’,
MASTER_PASSWORD=‘123456’,
MASTER_PORT=3306,
MASTER_LOG_FILE=‘Centos8-bin.000001’,
MASTER_LOG_POS=156;
然后然后start slave;
查看:show slave status\G 查看都已经连接:
再次在8上查看 已经连接2个:
SHOW GLOBAL STATUS LIKE ‘%semi%’;
第三步:验证
在8上创建数据 create database db1;
18和28上就可以马上查询到数据
当停掉28的服务 stop slave; 8创建数据,18正常可以查询, 因为半同步不是要求所有slave同步,有一台slave同步就可以
但是当18和28同时停掉的时候
在10.0.0.8 创建数据 就会 延迟3秒:
至此 msyql半同步设置完成!