CentOS8 在MySQL8.0 实现半同步复制

#原理

MySQL默认是异步的,不要求 必须全部同步到从节点才返回成功结果;

同步复制: 用户发请求到代理, 代理收到请求后写/更新数据库写入到二进制日志bin_log, 然后必须等数据发到所有的从节点, 从节点全部收到数据后, 主节点才返回给客户端的成功结果。

弊端: 客户端必须等到所有的从节点接收全部数据才收到成功结果,耗时长,效率低。

所以用半同步的方法解决,只要有一个从节点同步成功就返回成功结果。

#安装插件

安装主节点插件

bash 复制代码
mysql>INSTALL PLUGIN rpl_semi_sync_master SONAME 'semisync_master.so'; #永久安装插件

查看插件

bash 复制代码
mysql>SHOW PLUGINS; #查看插件

安装从节点插件(两个)

bash 复制代码
mysql>INSTALL PLUGIN rpl_semi_sync_slave SONAME 'semisync_slave.so';
bash 复制代码
mysql>SHOW PLUGINS; #查看插件

#主服务器Master配置

bash 复制代码
[root@master ~]#vim /etc/my.cnf.d/mysql-server.cnf
bash 复制代码
[mysqld]
server-id=8
log-bin

rpl_semi_sync_master_enabled=ON #修改此行,需要先安装semisync_master.so插件后,再重启,否则无法启动
rpl_semi_sync_master_timeout=3000 #设置3s内无法同步,也将返回成功信息给客户端

重启数据库

bash 复制代码
systemctl restart mysqld

插件开启状态

#从服务器Slave配置

打开配置文件

bash 复制代码
vim /etc/my.cnf.d/mysql-server.cnf

第一个从节点

bash 复制代码
[root@slave1 ~]#vim /etc/my.cnf.d/mysql-server.cnf
[mysqld]
server-id=18

rpl_semi_sync_slave_enabled=ON #修改此行,需要先安装semisync_slave.so插件后,再重启,否则无法启动

第二个从节点

bash 复制代码
[mysqld]
server-id=28
rpl_semi_sync_slave_enabled=ON #修改此行,需要先安装semisync_slave.so插件后,再重启,否则无法启动

验证查看

sql 复制代码
mysql>SHOW GLOBAL VARIABLES LIKE '%semi%';

#搭建主从关系

主节点查看

sql 复制代码
mysql> show master logs;

记录下来

sql 复制代码
CHANGE MASTER TO 
  MASTER_HOST='10.0.0.8',
  MASTER_USER='repluser',
  MASTER_PASSWORD='magedu',
  MASTER_PORT=3306,
MASTER_LOG_FILE='mysql-bin.000002', MASTER_LOG_POS=156;

创建账号并授权

sql 复制代码
#创建用户
mysql>create user repluser@"10.0.0.%" identified by "123456";

#授权
mysql>grant replication slave on *.* to repluser@"10.0.0.%";

从节点数据库执行

sql 复制代码
CHANGE MASTER TO 
  MASTER_HOST='10.0.0.8',
  MASTER_USER='repluser',
  MASTER_PASSWORD='magedu',
  MASTER_PORT=3306,
MASTER_LOG_FILE='mysql-bin.000002', MASTER_LOG_POS=156;

状态查看(成功)

sql 复制代码
mysql> start slave;

#验证

现在返回主节点查看

sql 复制代码
mysql> SHOW GLOBAL STATUS LIKE '%semi%';

#注意:如果已经实现主从复制,需要stop slave;start slave;

sql 复制代码
mysql> stop slave;
mysql> start slave;

mysql> SHOW GLOBAL STATUS LIKE '%semi%';
+----------------------------+-------+
| Variable_name | Value |
+----------------------------+-------+
| Rpl_semi_sync_slave_status | ON |
+----------------------------+-------+
1 row in set (0.00 sec)
相关推荐
2601_949833396 小时前
flutter_for_openharmony口腔护理app实战+预约管理实现
android·javascript·flutter
2603_949462109 小时前
Flutter for OpenHarmony社团管理App实战:预算管理实现
android·javascript·flutter
王泰虎11 小时前
安卓开发日记,因为JCenter 关闭导致加载不了三方库应该怎么办
android
2601_9495430114 小时前
Flutter for OpenHarmony垃圾分类指南App实战:主题配置实现
android·flutter
2601_9498333915 小时前
flutter_for_openharmony口腔护理app实战+知识实现
android·javascript·flutter
晚霞的不甘15 小时前
Flutter for OpenHarmony从基础到专业:深度解析新版番茄钟的倒计时优化
android·flutter·ui·正则表达式·前端框架·鸿蒙
鸟儿不吃草16 小时前
android的Retrofit请求https://192.168.43.73:8080/报错:Handshake failed
android·retrofit
Minilinux201816 小时前
Android音频系列(09)-AudioPolicyManager代码解析
android·音视频·apm·audiopolicy·音频策略
李子红了时16 小时前
【无标题】
android
Android系统攻城狮18 小时前
Android tinyalsa深度解析之pcm_close调用流程与实战(一百零四)
android·pcm·tinyalsa·音频进阶·音频性能实战·android hal