MySQL集群之实现半同步复制

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半同步设置完成!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值