MySQL基于gtid的主从同步配置

ops/2025/1/21 16:03:48/

一、主从复制的原理及工作过程

1、主从复制的原理

通过将MySQL的某一台主机(master)的数据复制到其他主机(slaves)上,并重新执行一遍来执行,复制过程中一台服务器充当主服务器,而其他一个或多个其他服务器充当从服务器。

2、主从复制的工作过程

1)MySQL将数据变化记录到二进制日志中;

2)Slave将MySQL的二进制日志拷贝到Slave的中继日志中;

3)Slave将中继日志中的事件在做一次,将数据变化,反应到自身(Slave)的数据库

二、实验:主从同步配置

1、环境准备

准备三台没有配置过MySQL的主机:

主机名IP地址主从架构
openEuler-1192.168.121.11
openEuler-2192.168.121.12
openEuler-3192.168.121.13

2、安装并配置MySQL

三台主机使用同一个安装MySQL方式:

# 这里以第一台主机为例
[root@openEuler-1 ~]# yum install -y mysql-server# 启动服务(开机自启动)
[root@openEuler-1 ~]# systemctl enable --now mysqld

主库配置:

# 配置id(这里以ip地址作为编号),并开启gtid
[root@openEuler-1 ~]# vim /etc/my.cnf
[root@openEuler-1 ~]# tail -n3 /etc/my.cnf
server_id=11
gtid_mode=ON
enforce-gtid-consistency=ON# 重启服务
[root@openEuler-1 ~]# systemctl restart mysqld# 授权用户
[root@openEuler-1 ~]# mysql
mysql> create user rep@'192.168.121.%' identified with mysql_native_password by '123456';
mysql> grant replication slave on *.* to rep@'192.168.121.%';

从库配置:

# 从库1:
[root@openEuler-2 ~]# vim /etc/my.cnf
[root@openEuler-2 ~]# tail -n3 /etc/my.cnf
server_id=12
gtid_mode=ON
enforce-gtid-consistency=ON
[root@openEuler-2 ~]# systemctl restart mysqld
[root@openEuler-2 ~]# mysqlmysql> change replication source to-> source_host='192.168.121.11',-> source_user='rep',-> source_password='123456',-> source_auto_position=1;mysql> start slave;mysql> show slave status \G# 从库2:
[root@openEuler-3 ~]# vim /etc/my.cnf
[root@openEuler-3 ~]# tail -n3 /etc/my.cnf
server_id=13
gtid_mode=ON
enforce-gtid-consistency=ON
[root@openEuler-3 ~]# systemctl restart mysqld
[root@openEuler-3 ~]# mysqlmysql> change replication source to-> source_host='192.168.121.11',-> source_user='rep',-> source_password='123456',-> source_auto_position=1;mysql> start slave;mysql> show slave status \G;

3、测试

在主库上建库建表插入数据:

mysql> create database db1;
Query OK, 1 row affected (0.02 sec)mysql> use db1
Database changedmysql> create table tb1(id int,name varchar(20));
Query OK, 0 rows affected (0.04 sec)mysql> insert into tb1 values(1,'Jack'),(2,'Bob'),(3,'Zed');
Query OK, 3 rows affected (0.03 sec)
Records: 3  Duplicates: 0  Warnings: 0mysql> select * from tb1;
+------+------+
| id   | name |
+------+------+
|    1 | Jack |
|    2 | Bob  |
|    3 | Zed  |
+------+------+
3 rows in set (0.00 sec)

从库上查看:

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| db1                |
| information_schema |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
5 rows in set (0.01 sec)mysql> select * from db1.tb1;
+------+------+
| id   | name |
+------+------+
|    1 | Jack |
|    2 | Bob  |
|    3 | Zed  |
+------+------+
3 rows in set (0.00 sec)

http://www.ppmy.cn/ops/151943.html

相关文章

Leetcode 3426. Manhattan Distances of All Arrangements of Pieces

Leetcode 3426. Manhattan Distances of All Arrangements of Pieces 1. 解题思路2. 代码实现 题目链接:3426. Manhattan Distances of All Arrangements of Pieces 1. 解题思路 这道题很惭愧,一开始没有搞定,后来看了答案想了想&#xff…

2025年01月17日Github流行趋势

项目名称:MiniCPM-o 项目地址url:https://github.com/OpenBMB/MiniCPM-o 项目语言:Python 历史star数:14181 今日star数:371 项目维护者:yiranyyu, iceflame89, yaoyuanTHU, LDLINGLINGLING, tc-mb 项目简介…

Java测试开发平台搭建(九)前端

1. 搭建前端vue环境 Vue3 安装 | 菜鸟教程 2. 创建项目 1.进入ui vue ui 2. create项目 3. 成功之后添加插件: cli-plugin-router vue-cli-plugin-vuetify 4. 添加依赖 axios 5. 点击任务开始运行 如果报错: 修改vue.config.jsconst { defineConfig }…

如何使用 Python 进行文件读写操作?

大家好,我是 V 哥。今天的内容来介绍 Python 中进行文件读写操作的方法,这在学习 Python 时是必不可少的技术点,希望可以帮助到正在学习 python的小伙伴。 以下是 Python 中进行文件读写操作的基本方法: 一、文件读取&#xff1…

mongoose 支持https踩坑纪实

简述 mongoose是C编写的嵌入式web服务,它能够支持https协议,可以简单的部署,但要做到完美部署,不是那么容易。 部署方法 本人使用的是最新的7.16版,以前版本似乎是要通过修改 头文件中的 MG_ENABLE_SSL 宏定义&…

电梯系统的UML文档05

Dispatcher 不控制实际的电梯组件,但它在软件系统中是重要的。每一个电梯有一个ispatcher,主要功能是计算电梯的移动方向、移动目的地以及保持门的打开时间。它和系统中除灯控制器以外的几乎所有控制对象交互。 安全装置也是一个环境对象,它…

如何使用 Redis 作为高效缓存

如何使用 Redis 作为高效缓存 Redis(Remote Dictionary Server)是一个高性能的 内存存储系统,通常被用作 缓存 来加速数据访问,提高应用的吞吐量和响应速度。本文详细讲解如何使用 Redis 作为高效缓存,包括基本原理、…

DNVS许可管理

在全球经济一体化的大背景下,合规管理成为了企业持续稳健发展的关键要素。DNVS许可管理作为一种国际领先的许可认证体系,以其严格的标准和专业的审核流程,帮助企业实现合规管理,为企业的稳健发展保驾护航。 一、DNVS许可管理的核…