当前位置: 首页 > article >正文

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

#原理

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

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

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

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

#安装插件

安装主节点插件 

mysql>INSTALL PLUGIN rpl_semi_sync_master SONAME 'semisync_master.so'; #永久安装插件

查看插件

mysql>SHOW PLUGINS; #查看插件

安装从节点插件(两个)

mysql>INSTALL PLUGIN rpl_semi_sync_slave SONAME 'semisync_slave.so';
mysql>SHOW PLUGINS; #查看插件

 #主服务器Master配置

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

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

重启数据库

systemctl restart mysqld

插件开启状态 

#从服务器Slave配置

打开配置文件 

vim /etc/my.cnf.d/mysql-server.cnf

第一个从节点 

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

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

第二个从节点

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

验证查看

mysql>SHOW GLOBAL VARIABLES LIKE '%semi%';

  

 #搭建主从关系

主节点查看 

mysql> show master logs;

记录下来

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;

创建账号并授权

#创建用户
mysql>create user repluser@"10.0.0.%" identified by "123456";

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

从节点数据库执行 

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;

 状态查看(成功)

mysql> start slave;

#验证

现在返回主节点查看

mysql> SHOW GLOBAL STATUS LIKE '%semi%';

 

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

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)


http://www.kler.cn/a/403683.html

相关文章:

  • 操作系统大会2024 | 麒麟信安根植openEuler社区,持续技术创新 共拓新应用 探索新机遇
  • 介绍一下strncmp(c基础)
  • 【Three.js基础学习】28.Coffee Smoke
  • 《人工智能深度学习的基本路线图》
  • reactflow 中 useStoreApi 模块作用
  • Elasticsearch:管理和排除 Elasticsearch 内存故障
  • Linux光标快捷键
  • 秋招总结与感悟
  • AI眼镜拐点到了,全品类AI硬件还会远吗?
  • SimbaSchema在数据云平台中的可观测性实践与应用
  • 【HOT100第四天】除自身以外数组的乘积,矩阵置零,螺旋矩阵,旋转图像
  • phpMyAdmin/PHP反序列化/sqli-labs/upload/pikachu/DVWA--靶场搭建--超详细教程!!!
  • 【01】Selenium+Python 入门案例
  • React Native的开发流程是怎样的?
  • 【蓝桥杯算法】Java的基础API
  • 【Node.js】Node.js 和浏览器之间的差异
  • Figma插件指南:12款提升设计生产力的插件
  • Debug-030-浏览器中F12审查伪类元素样式
  • 计算机网络技术专业,热门就业方向和就业前景
  • vue实现滚动下拉加载更多
  • 如何确保Java爬虫程序的稳定性和安全性?
  • cesium 地图 事件触发
  • OPC UA 服务器
  • jd-easyflow中inclusive的用法
  • C++基础入门篇
  • Dowex 50WX8 ion-exchange resin可以用于去除水中的金属离子(如钠、钾、镁、钙等)和其他杂质,提高水质,11119-67-8