6. Mysql里面的GTID 全局事务标识 介绍

GTID学习记录 来源

  1. 知乎阿里云:MySQL 基于GTID复制实现的工作原理
  2. MySQL的GTID主从搭建及内部原理
  3. MySQL5.7杀手级新特性:GTID原理与实战


1 什么是GTID

GTID (Global Transaction IDentifier) 是全局事务标识。它具有全局唯一性,一个事务对应一个GTID。唯一性不仅限于主服务器,GTID在所有的从服务器上也是唯一的。一个GTID在一个服务器上只执行一次,从而避免重复执行导致数据混乱或主从不一致。

在传统的复制里面,当发生故障需要主从切换时,服务器需要找到binlog和pos点,然后将其设定为新的主节点开启复制。相对来说比较麻烦,也容易出错。在MySQL 5.6里面,MySQL会通过内部机制自动匹配GTID断点,不再寻找binlog和pos点。我们只需要知道主节点的ip,端口,以及账号密码就可以自动复制。


2 GTID的组成部分

  • GDIT由两部分组成:GTID = source_id:transaction_id。
  1. 其中source_id是产生GTID的服务器,即是server_uuid,在第一次启动时生成(sql/mysqld.cc: generate_server_uuid()),并保存到DATADIR/auto.cnf文件里。
  2. transaction_id是序列号(sequence number),在每台MySQL服务器上都是从1开始自增长的顺序号,是事务的唯一标识。

例如:3E11FA47-71CA-11E1-9E33-C80AA9429562:23 GTID 的集合是一组GTIDs,可以用source_id+transaction_id范围表示,例如:3E11FA47-71CA-11E1-9E33-C80AA9429562:1-5 复杂一点的:如果这组 GTIDs 来自不同的 source_id,各组 source_id 之间用逗号分隔;如果事务序号有多个范围区间,各组范围之间用冒号分隔,例如:3E11FA47-71CA-11E1-9E33-C80AA9429562:23,3E11FA47-71CA-11E1-9E33-C80AA9429562:1-5


3 GTID如何产生

GTID的生成受GTID_NEXT控制。

在主服务器上,GTID_NEXT默认值是AUTOMATIC,即在每次事务提交时自动生成GTID。它从当前已执行的GTID集合(即gtid_executed)中,找一个大于0的未使用的最小值作为下个事务GTID。同时在实际的更新事务记录之前,将GTID写入到binlog(set GTID_NEXT记录)。 在Slave上,从binlog先读取到主库的GTID(即get GTID_NEXT记录),而后执行的事务采用该GTID。


4 GTID的工作原理

GTID在所有主从服务器上都是不重复的。所以所有在从服务器上执行的事务都可以在binlog找到。一旦一个事务提交了,与拥有相同GTID的后续事务都会被忽略。这样可以保证从服务器不会重复执行同一件事务。

当使用GTID时,从服务器不需要保留任何非本地数据。使用数据都可以从replicate data stream。


5 GTID的生成和使用由以下几步组成:

  1. 主服务器更新数据时,会在事务前产生GTID,一同记录到binlog日志中。
  2. binlog传送到从服务器后,被写入到本地的relay log中。从服务器读取GTID,并将其设定为自己的GTID(GTID_NEXT系统)。
  3. sql线程从relay log中获取GTID,然后对比从服务器端的binlog是否有记录。
  4. 如果有记录,说明该GTID的事务已经执行,从服务器会忽略。
  5. 如果没有记录,从服务器就会从relay log中执行该GTID的事务,并记录到binlog。

6 GTID和Binlog的关系

MySQL5.7杀手级新特性:GTID原理与实战

相关推荐

  1. 6. Mysql里面GTID 全局事务标识 介绍

    2024-04-15 01:52:04       15 阅读
  2. 关于MySQL全局事务标识符GTID

    2024-04-15 01:52:04       9 阅读
  3. mysql全局事务变量GTID

    2024-04-15 01:52:04       25 阅读
  4. MySQLGTID

    2024-04-15 01:52:04       11 阅读
  5. MySQL事务介绍

    2024-04-15 01:52:04       12 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-15 01:52:04       19 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-15 01:52:04       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-15 01:52:04       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-15 01:52:04       20 阅读

热门阅读

  1. 6.5-1Python之列表嵌套字典的使用

    2024-04-15 01:52:04       16 阅读
  2. C#面:如何使用 IFormattable 接口实现格式化输出

    2024-04-15 01:52:04       20 阅读
  3. js和ES的关系

    2024-04-15 01:52:04       23 阅读
  4. v3+antd+echarts的bug记录

    2024-04-15 01:52:04       15 阅读
  5. 【springboot开发】PO、DTO等对象的基本概念

    2024-04-15 01:52:04       19 阅读
  6. js中return的作用有什么?

    2024-04-15 01:52:04       17 阅读
  7. nodejs安装常用命令

    2024-04-15 01:52:04       18 阅读
  8. [EFI]Z420电脑 Hackintosh 黑苹果efi引导文件

    2024-04-15 01:52:04       17 阅读
  9. 页面不活跃状态时 setTimeout不执行

    2024-04-15 01:52:04       15 阅读
  10. 微信小程序压缩图片到200kb,递归设置压缩质量

    2024-04-15 01:52:04       15 阅读
  11. 怎么用docker安装MySQL

    2024-04-15 01:52:04       18 阅读
  12. 富格林:出金异常警惕黑幕陷阱受骗

    2024-04-15 01:52:04       17 阅读