首页 > 数据库 >MySQL基于GTID同步模式搭建主从复制

MySQL基于GTID同步模式搭建主从复制

时间:2024-09-13 18:24:09浏览次数:11  
标签:主从复制 同步 slave MySQL sync master mysql GTID

系列文章目录

rpmbuild构建mysql5.7.42版本的rpm包


文章目录


一、mysql-5.7.42RPM包构建

1、首先请查看顶部的系列文章目录,通过这篇文章构建出mysql的rpm安装包
2、接着将构建好的rpm包上传到服务器,至此安装包准备完毕,接下来搭建GTID同步模式的主从复制

二、同步模式分类介绍

1.异步同步模式

在这里插入图片描述

异步同步模式是 MySQL 默认的同步策略模式。
客户端在向服务端发送请求后,master处理完之后,直接返回客户端结果,接着在将对应的log信息发送给 slave节点。

异步同步模式缺点

主库在执行完客户端提交的事务后会立即将结果返回给客户端,并不关心从库是否已经接收并处理,
这样就会有一个问题,主库如果crash掉了,此时主库上已经提交的事务可能并没有传到从库上,
如果此时,强行将从提升为主,可能导致新的主库上数据不完整

2.半同步模式

在这里插入图片描述
半同步模式与异步同步的模式最大的区别

1、主库在执行完客户端提交的事务后不是立刻返回给客户端,而是等待至少一个从库接收到并写到relay_log中才返回给客户端
2、半同步模式也是基于异步复制的基础上进行的,无非是半同步模式需要安装异步插件完成

2.1.实现半同步操作流程

1、检测是否支持动态安装插件模式
mysql > select @@have_dynamic_loading; #返回YES为支持,反之不支持
2、在 master 上安装 master 对应的插件.slave节点也可以安装,此处不做示例
mysql> INSTALL PLUGIN rpl_semi_sync_master SONAME 'semisync_master.so'; #执行安装
mysql >show global variables like 'rpl_semi%'; #查看安装插件后的参数配置
+-------------------------------------------+------------+
| Variable_name                             | Value      |
+-------------------------------------------+------------+
| rpl_semi_sync_master_enabled              | OFF        |
| rpl_semi_sync_master_timeout              | 10000      |
| rpl_semi_sync_master_trace_level          | 32         |
| rpl_semi_sync_master_wait_for_slave_count | 1          |
| rpl_semi_sync_master_wait_no_slave        | ON         |
| rpl_semi_sync_master_wait_point           | AFTER_SYNC |
+-------------------------------------------+------------+
3、master 服务器和 slave 服务器都开启主从复制插件功能
mysql > set global rpl_semi_sync_master_enabled=ON; #调整半同步插件参数值
mysql > show global variables like 'rpl_semi%';
+-------------------------------------------+------------+
| Variable_name                             | Value      |
+-------------------------------------------+------------+
| rpl_semi_sync_master_enabled              | ON         |
| rpl_semi_sync_master_timeout              | 10000      |
| rpl_semi_sync_master_trace_level          | 32         |
| rpl_semi_sync_master_wait_for_slave_count | 1          |
| rpl_semi_sync_master_wait_no_slave        | ON         |
| rpl_semi_sync_master_wait_point           | AFTER_SYNC |
| rpl_semi_sync_slave_enabled               | ON         |
| rpl_semi_sync_slave_trace_level           | 32         |
+-------------------------------------------+------------+
4、salve 节点半同步复制模式
mysql >stop slave io_thread;
mysql >start slave io_thread;
5、在 master 上查看 slave 信息。 
这里我们看到 Rpl_semi_sync_master_clients=1,则表示有一个 salve 节点连接上了
mysql > show global status like '%semi%';
+--------------------------------------------+-------+
| Variable_name                              | Value |
+--------------------------------------------+-------+
| Rpl_semi_sync_master_clients               | 1     |
| Rpl_semi_sync_master_status                | ON    |
+--------------------------------------------+-------+
15 rows in set
Time: 0.011s

2.2.半同步问题总结

问题解答
slave 节点响应 master 延迟当 master 发送给 slave 节点 binary log 之后,需要等待 slave 的响应。有时可能 slave 节点响应很慢,master 不能一直等待,这样会导致客户端请求超时情况,可以通过下面的参数进行设置。该参数的单位是毫秒,默认是 10 秒,推荐设置大一点。因为超时之后,master 会自动切换为异步复制。rpl_semi_sync_master_timeout
半同步模式自动转为异步同步模式上方提到了,如果超时之后,半同步模式会自动切换为异步复制模式。
master 接收 slave 节点数量,响应客户端。当 master 需要将 binary log 发送给多个 slave 节点时,如果 slave 节点存在多个,master 都要等待 slave 一一响应之后才回复客户端,这也是一个特别耗时的过程,可以通过下面的参数进行设置。rpl_semi_sync_master_wait_for_slave_count #默认是1
当半同步模式自动切换为异步之后,如何切换为半同步模式。这时候需要手动切换模式。就是关闭 io_thread,再开启 io_thread

2.3.半同步一致性

半同步复制模式极大程度上提高了主从复制的一致性。同时在 MySQL5.7+的版本增加了另外一个参数,
让复制的一致性更加可靠。这个参数就是rpl_semi_sync_master_wait_point,需要在 master 上执行。
mysql > set global rpl_semi_sync_master_wait_point = 'x';

该参数有两个值。一个值是 AFTER_SYNC,一个值是 AFTER_COMMIT。默认是 AFTER_SYNC。区别如下表格所示
AFTER_COMMITmaster 在将事务写入 binary log 之后,然后发送给 slave。同时也会自动提交 master 的事务。等 slave 响应之后,master 接着响应给客户端信息。
AFTER_SYNCmaster 在将事务写入 binary log 之后,然后发送给 slave。等待 slave 响应之后,才会提交 master 的事务,接着响应给客户端信息。

2.4.异步与半同步对比

异步同步模式是直接返回给客户端在处理 slave 的问题,如果 master 响应给客户端成功信息,在处理 slave 问题时,服务挂掉了,此时就会出现数据不一致。
半同步模式需要等待 slave 节点做出响应,master 才会响应客户端,如果 salve 响应较慢就会造成客户端等待时间较长
半同步模式master 等待 slave 响应之后才会响应给客户端,此方式极大程度的保证了数据的一致性,为主从复制的数据一致性提供了更可靠的保证。也推荐使用该方式进行主从复制操作。

3.GTID同步

如下方所示

三、GTID同步介绍

1.gtid介绍

GTID是一种全局事务ID,它是在master上已经提交的事务,slave直接根据该ID进行复制操作。
该操作替代了binary log + postion的方式。使得主从复制的配置操作更加简单。

2.gtid组成

server-id不是MySQL配置文件中id,而是每一个MySQL服务在启动时,都会生成一个全局随机唯一的ID。transaction-id则是事务的ID,创建事务是会自动生成一个ID。

GTID = server-id + transaction-id组成

3.gtid工作原理

1、当一个事务在主库端执行并提交时,会产生GITD,一同记录到binlog日志中
2、binlog传输到slave,并存储到slave的relay-log(中继日志)中,,读取GTID的这个值设置gtid_next变量,即告诉Slave,下一个要执行的GTID值
3、sql线程从relay log中获取GTID,然后对比slave端的binlog是否有该GTID
4、如果有记录,说明该GTID的事务已经执行,slave会忽略
5、如果没有记录,slave就会执行该GTID事务,并记录该GTID到自身的binlog。在读取执行事务前会先检查其他session持有该GTID,确保不被重复执行。
6、在解析过程中会判断是否有主键,如果没有就用二级索引,如果没有就用全部扫描

4.gtid优缺点

优点缺点
根据 GTID 可以快速的确定事务最初是在哪个实例上提交的。必须确保主从库的引擎一致
简单的实现 failover,不用以前那样在需要找 log_file 和 log_pos。不允许一个SQL同时更新一个事务引擎和非事务引擎的表
更简单的搭建主从复制,确保每个事务只会被执行一次。/
比传统的复制更加安全,一个 GTID 在一个服务器上只执行一次,避免重复执行导致数据混乱或者主从不一致。/
GTID是连续的没有空洞的,保证数据的一致性,零丢失/
GTID 用来代替classic的复制方法,不再使用 binlog+pos 开启复制。而是使用 master_auto_postion=1 的方式自动匹配 GTID 断点进行复制。/
GTID 的引入,让每一个事务在集群事务的海洋中有了秩序,使得 DBA 在运维中做集群变迁时更加方便/

四、搭建主从复制

环境准备

ip分类
192.168.56.130master
192.168.56.131slave

1.两台机器分别安装mysql-rpm包

这个rpm包就是第一步已构建好的rpm包

[root@mysql1 ~]# rpm -ivh city-mysql5.7.42-1-1.x86_64.rpm
Preparing...                          ################################# [100%]
Updating / installing...
   1:city-mysql5.7.42-1-1             ################################# [100%]
useradd: warning: the home directory already exists.
Not copying any file from skel directory into it.
Creating mailbox file: File exists
Datadir /export/servers/data/my3306 will been created,instance install will continue
Starting MySQL..... SUCCESS! 
Install successful!!!
The  Password of mysql user root is : 0gvzJr66iNs5
 1. mysql进程可以使用systemctl启停;
 2. mysql未设置开机自启;
 3. mysql登陆方式:mysql -uroot -p -S /export/servers/data/my3306/run/mysqld.sock
 4. 建议修改root密码
 5. 参数文件中设置为只读(read_only=1 super_read_only=1),如需要请将参数值该为零。

2.检查两台机器my.cnf配置文件

因为在安装了构建好的rpm包后,my.cnf文件已经封装进去了,因此在安装后,只需要略微调试相关参数,即可使用。下方只列出了几个需要修改的重要参数,其余参数再次不展示
master节点

检查my.cnf文件中是否包含了开启gtid的相关参数
server_id               = 1   #自定义
log_bin                 = ON
binlog_format           = ROW
gtid_mode				= ON
enforce_gtid_consistency = ON
innodb_buffer_pool_size= 1G #根据服务器配置调整

slave节点

server_id               = 2 #自定义 与master不同即可
log_bin                 = mysql-bin
binlog_format           = ROW
gtid_mode				= ON
enforce_gtid_consistency = ON
log_slave_updates		= ON
read_only				= ON  #从库开启只读
super_read_only			= ON  #从库开启只读
innodb_buffer_pool_size= 1G #根据服务器配置调整

参数调整完成后,需要重启master-slave两个节点的MySQL,重启完成后,下一步就开始搭建主从关系

3.创建主从复制用户

登录主库执行

mysql > grant replication slave on *.* to 'repl'@'%' identified by '123456';
mysql >  flush privileges;

4.搭建主从

登录从库操作

mysql > reset master; 
mysql > change master to master_host='主库IP', master_port=主库端口,master_user='repl' ,master_password='xx' ,master_auto_position=1;
mysql > start slave; #开启主从复制
mysql > show slave status\G; #查看主从状态

当IO thread和SQL thrad 都为YES 说明主从搭建完毕

5.验证

登录主库操作

mysql> show master status;
+------------------+-----------+--------------+------------------+---------------------------------------------------+
| File             | Position  | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set                                 |
+------------------+-----------+--------------+------------------+---------------------------------------------------+
| mysql-bin.010602 | 590048831 |              |                  | 52cf1b46-f308-11ec-a372-fa163e258462:1-1404783188 |
+------------------+-----------+--------------+------------------+---------------------------------------------------+
1 row in set (0.00 sec)

如上所示,主库已产生了binlog日志及记录了当前gtid执行的位置。至此基于GTID同步模式的主从复制搭建完成

五、主从复制原理

在这里插入图片描述

1、服务器开启二进制日志,主服务器会把sql操作记录通过多dump线程写入到主服务器的二进制日志中
2、从服务器的io 线程向主服务器二进制日志发送请求,master 服务器在接收到请求之后,根据偏移量将新的 binary log 发送给 slave 服务器。
3、slave 服务器收到新的 binary log 之后,写入到自身的 relay log 中,这就是所谓的中继日志
4、slave 服务器,单独开启一个 sql thread 读取 relay log 之后,写入到自身数据中

总结

本篇文章主要针对mysql5.7版本的同步模式分类、基于gtid同步模式搭建主从写的文章,对于mysql的构建安装过程可参考顶部的链接文章。希望这几篇文章可以帮助到大家

标签:主从复制,同步,slave,MySQL,sync,master,mysql,GTID
From: https://blog.csdn.net/weixin_50902636/article/details/142202936

相关文章

  • MySQL数据库索引设计的主要原则
    在MySQL数据库中,索引设计是提高查询性能的关键因素之一。什么是索引?索引是数据库中用于提高数据检索效率的数据结构。它类似于书籍的目录,允许用户快速找到所需的数据,而无需扫描整个数据集。在数据库系统中,索引通常用于加速查询操作,特别是对于大型数据集。以下是索引的一些关......
  • mysql创建视图
    --CreatetablecreatetableODS_QMS.QMS_TRIAL_PROVIDE_BAD_INFORMATION(idVARCHAR2(36),date_tVARCHAR2(30),factoryVARCHAR2(16),provide_codeVARCHAR2(16),provide_nameVARCHAR2(16),marer......
  • 2024Mysql And Redis基础与进阶操作系列(1)作者——LJS[含MySQL的下载、安装、配置详解
    目录1.数据库与数据库管理系统1.1数据库的相关概念1.2数据库与数据库管理系统的关系 1.3 常见的数据库简介Oracle1. 核心功能2. 架构和组件3. 数据存储和管理4. 高可用性和性能优化5. 安全性6. 版本和产品7. 工具和接口 SQLServer1. 核心功能2. 架构和组件3. 数据......
  • 20240913_155935 mysql 触发器
    建表需求创建一个日志表记录teacher表的操作日志情况增删改的相关信息要保存起来方便定期查看明确字段表名:log_info列信息idactioninfotime创建表格CREATETABLElog_info( idINTPRIMARYKEYAUTO_INCREMENT, action_nameVARCHAR(11), infoVARCHAR(111), act_......
  • MYSQL进阶-索引篇
    索引(SQL主要的优化方式)介绍:索引(index)是帮助MySQL高效获取数据的数据结构(有序)。在数据之外,数据库系统还维护着满足特定查找算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构上实现高级查找算法,这种数据结构就是索引。示意图:索引的优缺点......
  • jpa适配mysql切换达梦可能的坑
    1、liquibase脚本(1)达梦数据库不支持,修改字段varchar改成blob<changeSetauthor="ly"id="v3.0_4_202307111505_101"><renameColumntableName="PC_SS_ZRQD"oldColumnName="BHNR"newColumnName="BHNR"columnDataType=&q......
  • AWS EC2上搭建MySQL8.0.34
    安装MySQL8.0.34初始化结束后密码位置:error日志中dump之前需检查磁盘空间,需至少预留mysql数据2倍的空间df-h需要导出的库和表库:dw_dbproxy_config表:server_info安装脚本#!/bin/sh#安装8.0版本#########################mysql8_install(){parentDir=/data......
  • MYSQL进阶-SQL优化篇
    SQL优化-插入数据批量插入:(一次尽量不超过1000条)Insertintotbtestvalues(1,'Tom'),(2,'cat'),(3,Jerny');手动事务提交:starttransaction;insertintotb_testvalues(1,'Tom'"),(2,'Cat'),(3,jerry');insertintotbtestva......
  • MYSQL进阶-锁
    锁概述锁是计算机协调多个进程或线程并发访问某一资源的机制。在数据库中,除传统的计算资源(CPU、RAM、I/O)的争用以外,数据也是一种供许多用户共享的资源。如何保证数据并发访问的一致性、有效性是所有数据库必须解决的一个问题,锁冲突也是影响数据库并发访问性能的一个重要因素......
  • 主从复制断开连接问题
    跳过复制失败的错误直接跳过当前事务##GTID模式下,通过以下命令解决STOPSLAVE;SETGTID_NEXT='xxxxxx:yyy';-----设置需要跳过的gtideventBEGIN;COMMIT;SETGTID_NEXT='AUTOMATIC';STARTSLAVE;##非GTID模式下,可以通过下面的命令来解决stopslave;setsql_sla......