了解 Mysql基于GTID的复制模式
GTID定义
GTID( Global Transaction Identifier)全局事务标识。GTID是5.6 版本引入的一个有关于主从复制的重大改进,相对于之前版本基于Binlog文件+Position的主从复制,基于GTID的主从复制,数据一致性更高,主从数据复制更健壮,主从切换、故障切换不易出错,很少需要人为介入处理。
表示方式
GTID = server_uuid:transaction_id
其GTID通常会记录在MySQL的系统变量@@GLOBAL.gtid_executed 以及系统表mysql.gtid_executed中,系统变量@@GLOBAL.gtid_executed 在内存中,属于非持久化存储,而系统表mysql.gtid_executed属于持久化存储。
GTID比传统复制的优势
- 更简单的搭建主从复制
- 更简单的实现fAIlover (主从切换),不用以前那样一步一步的去找
log_file和log_pos - GTID是连续的没有空洞的,保证数据的一致性,零丢失。
- 复制集群有一个统一的方式识别复制位置,给集群管理带来了便利
GTID的限制
- 在一个事务里面混合使用引擎如Innodb,myisam,造成多个GTIDS
CREATE TABLE…..SELECT不能使用CREATE TEMPORARY TABLE and DROP TEMPORARY TABLE不能在事务内使用
主从复制流程图


GTID生命周期
- 当一个事务在一个主库上被执行和提交,那么这个事务就会被分配一个和该主库uuid相关联的gtid,这个gtid被写入到主库的binlog文件中。
- 当这个binlog文件达到最大值发生轮转,或者MySQL Server关闭时,上一个binlog文件中的事务GTID将会被写入到
mysql.gtid_executed表中。 - 事务提交时,该事务的gtid会很快的添加到系统变量
@@GLOBAL.gtid_executed,但是系统表 mysql.gtid_executed 则不会,应为有部分gtid还在binlog中,需要等到binlog轮转或者mysqlServer关闭时才会写入到mysql。gtid_executed表中. - 主库上的binlog通过主从复制协议传送到从库,并写入到从库的relay log(中继日志), 从库读取relay log中的gtid和对应的事务信息,把
gtid_next设置为该gtid值,使得从库使用该gtid值应用其对应的事务 - 如果多个线程并发应用同一个事务,比如多个线程设置gtid_next为同一个值,MySQL Server 只允许其中一个线程执行,
gtid_owned系统变量记录着谁拥有该GTID.
传统更换GTID复制模式
- 配置GTID
- 所有服务器设置
global.read_only参数,等待主从服务器同步完毕;mysql> SET @@global.read_only = ON;
- 依次重启主从服务器;
- 使用change master 更新主从配置;
mysql> CHANGE MASTER TO MASTER_HOST = host, MASTER_PORT = port, MASTER_USER = user, MASTER_PASSWORD = password, MASTER_AUTO_POSITION = 1;
5、开启复制mysql> START SLAVE;
6、验证主从复制mysql> show slave status \G
上一篇:解析SQL Server中datetimeset转换datetime类型问题
栏 目:其它数据库
本文标题:了解 Mysql基于GTID的复制模式
本文地址:https://zz.feitang.co/shujuku/32595.html
您可能感兴趣的文章
- 12-22使用mysql记录从url返回的http GET请求数据操作
- 12-22详解sql中exists和in的语法与区别
- 12-22hive从mysql导入数据量变多的解决方案
- 12-22如何为PostgreSQL的表自动添加分区
- 12-22postgresql 实现得到时间对应周的周一案例
- 12-22sqoop export导出 map100% reduce0% 卡住的多种原因及解决
- 12-22mysql查询条件not in 和 in的区别及原因说明
- 12-22解决mysql使用not in 包含null值的问题
- 12-22解决从集合运算到mysql的not like找不出NULL的问题
- 12-22postgresql 实现多表关联删除


阅读排行
推荐教程
- 12-11mysql代码执行结构实例分析【顺序、分支、循环结构】
- 12-08添加mysql的用户名和密码是什么语句?
- 12-20PhpMyAdmin出现错误数据无法导出怎么办?
- 12-19Redis中实现查找某个值的范围
- 12-15浅析mysql迁移到clickhouse的5种方法
- 12-15CentOS7 64位下MySQL5.7安装与配置教程
- 12-14Mysql大型SQL文件快速恢复方案分享
- 12-14mysql 5.7.27 安装配置方法图文教程
- 12-13MySQL给新建用户并赋予权限最简单的方法
- 12-13关于MySQL索引的深入解析





