MySQL8.0+数据库GTID主从模式搭建

1、准备事项

1.1、完成主从库数据库安装

参见: MySQL数据库8.0+版本部署安装-CSDN博客

部署环境[例]:

  • 主库:192.168.179.153:3306
  • 从库:192.168.179.154:3306

1.2、配置文件检查

主从库开启GTID模式

// 主从库均修改,修改从库配置文件,在[mysqld]下添加如下配置

$ vim /etc/my.cnf

gtid_mode = on

enforce_gtid_consistency = on

1.3、主从库server-id配置

需检查server-id配置,为主从架构中的所有MySQL实例都分别指定一个独特的互不相同的server-id

主从server-id必须不同。

2、主从搭建

2.1、创建主从复制用户

// 主库执行

$ mysql -uroot -p

SQL> create user repl@'%' identified with 'mysql_native_password' by 'repl@123';

SQL> grant replication slave on *.* to 'repl'@'%';

SQL> exit;

​​​​​​​2.2、备份主库数据

// 主库执行,创建备份文件目录

$ mkdir /data/backup

$ cd /data/backup

## 在主库上全库备份,不带gtid

$ /usr/local/mysql/bin/mysqldump -uroot -p -S /data/mysql/mysql3306/tmp/mysql.sock --set-gtid-purged=OFF --all-databases --single-transaction --master-data=2 --triggers --routines --events >Fulldb.sql

备份完成后,将备份文件scp至备库。

​​​​​​​2.3、恢复从库数据

// 从库执行

$ mysql -uroot -p

SQL> reset master;

SQL> exit;

$ time mysql -uroot -p -S /data/mysql/mysql3306/tmp/mysql.sock < Fulldb.sql

恢复过程无报错即可。

​​​​​​​2.4、从库开启同步

// 从库执行

$ mysql -uroot -p

SQL> change master to master_host='192.168.179.153',master_port=3306,master_user='repl',master_password='repl@123',master_auto_position=1;
Query OK, 0 rows affected, 8 warnings (7.38 sec)

SQL> start slave;

​​​​​​​2.5、从库设置只读

SQL> set global super_read_only=1;
SQL> set global read_only=1;
##需同步修改参数文件,避免MySQL重启后参数失效。在配置[mysqld]下添加如下配置

$ vim /etc/my.cnf

read_only = 1

super_read_only=1

##此配置限制管理员操作备库,看情况设置。备库数据恢复完在设置 ,否则无权限导入

修改完配置文件,需重启主从数据库。

​​​​​​​2.6、检查主从同步状态

// 从库执行

$ mysql -uroot -p

SQL> show slave status\G

需满足以下几点:

  1. Slave_IO_Running、Slave_SQL_Running " YES "
  2. Retrieved_Gtid_Set(从库接收到主库GTID事务) == Executed_Gtid_Set(从库当前执行到的GTID事务)
相关推荐
一 乐1 小时前
学籍管理平台|在线学籍管理平台系统|基于Springboot+VUE的在线学籍管理平台系统设计与实现(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·学习
Java探秘者5 小时前
Maven下载、安装与环境配置详解:从零开始搭建高效Java开发环境
java·开发语言·数据库·spring boot·spring cloud·maven·idea
2301_786964365 小时前
3、练习常用的HBase Shell命令+HBase 常用的Java API 及应用实例
java·大数据·数据库·分布式·hbase
阿维的博客日记6 小时前
图文并茂解释水平分表,垂直分表,水平分库,垂直分库
数据库·分库分表
wrx繁星点点7 小时前
事务的四大特性(ACID)
java·开发语言·数据库
小小娥子7 小时前
Redis的基础认识与在ubuntu上的安装教程
java·数据库·redis·缓存
DieSnowK7 小时前
[Redis][集群][下]详细讲解
数据库·redis·分布式·缓存·集群·高可用·新手向
-XWB-8 小时前
【MySQL】数据目录迁移
数据库·mysql
老华带你飞8 小时前
公寓管理系统|SprinBoot+vue夕阳红公寓管理系统(源码+数据库+文档)
java·前端·javascript·数据库·vue.js·spring boot·课程设计
我明天再来学Web渗透8 小时前
【hot100-java】【二叉树的层序遍历】
java·开发语言·数据库·sql·算法·排序算法