了解 Mysql基于GTID的复制模式


本文摘自PHP中文网,作者coldplay.xixi,侵删。

mysql教程栏目介绍Mysql基于GTID的复制模式是什么

推荐(免费):mysql教程

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比传统复制的优势

  1. 更简单的搭建主从复制
  2. 更简单的实现failover (主从切换),不用以前那样一步一步的去找log_filelog_pos
  3. GTID是连续的没有空洞的,保证数据的一致性,零丢失。
  4. 复制集群有一个统一的方式识别复制位置,给集群管理带来了便利

GTID的限制

  1. 在一个事务里面混合使用引擎如Innodb,myisam,造成多个GTIDS
  2. CREATE TABLE…..SELECT 不能使用
  3. CREATE TEMPORARY TABLE and DROP TEMPORARY TABLE 不能在事务内使用

主从复制流程图


GTID生命周期

  1. 当一个事务在一个主库上被执行和提交,那么这个事务就会被分配一个和该主库uuid相关联的gtid,这个gtid被写入到主库的binlog文件中。
  2. 当这个binlog文件达到最大值发生轮转,或者MySQL Server关闭时,上一个binlog文件中的事务GTID将会被写入到mysql.gtid_executed表中。
  3. 事务提交时,该事务的gtid会很快的添加到系统变量@@GLOBAL.gtid_executed,但是系统表 mysql.gtid_executed 则不会,应为有部分gtid还在binlog中,需要等到binlog轮转或者mysqlServer关闭时才会写入到mysql。gtid_executed表中.
  4. 主库上的binlog通过主从复制协议传送到从库,并写入到从库的relay log(中继日志), 从库读取relay log中的gtid和对应的事务信息,把gtid_next设置为该gtid值,使得从库使用该gtid值应用其对应的事务
  5. 如果多个线程并发应用同一个事务,比如多个线程设置gtid_next为同一个值,MySQL Server 只允许其中一个线程执行,gtid_owned系统变量记录着谁拥有该GTID.

传统更换GTID复制模式

  1. 配置GTID
  2. 所有服务器设置global.read_only参数,等待主从服务器同步完毕;

    1

    mysql> SET @@global.read_only = ON;

  3. 依次重启主从服务器;
  4. 使用change master 更新主从配置;

    1

    2

    3

    4

    5

    6

    mysql> CHANGE MASTER TO

    MASTER_HOST = host,

    MASTER_PORT = port,

    MASTER_USER = user,

    MASTER_PASSWORD = password,

    MASTER_AUTO_POSITION = 1;

    5、开启复制

    1

    mysql> START SLAVE;

    6、验证主从复制

    1

    mysql> show slave status \G

以上就是了解 Mysql基于GTID的复制模式的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

mysql递归查询的3种实现方式实例

如何利用amoeba实现mysql数据库的读写分离

远程连接mysql数据库没有权限怎么办

mysql中的update语句怎么使用

mysql怎么创建数据库

mysql文件存储图文详解

mysql索引提高查询效率的原因何在

mysql存储过程中游标如何遍历

mysql建表语句是什么

mysql多层级结构-树搜索介绍

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...