暂无图片
暂无图片
暂无图片
暂无图片
1
暂无图片

GTID特性

原创 谭磊Terry 2022-05-18
216

存储定义

  • GTID(Global Transaction Identifier 全局事务标识符)
  • mysql.gtid_executed表:GTID持久化的介质,GTID模块初始化的时候会读取这个表来作为获取gtid_executed变量的基础。
    • 当启用系统变量log_bin和log_slave_updates时,表mysql.gtid_executed中的GTID SET不包括最后正在使用的二进制日志文件中的GTID。
    • 执行 FLUSH LOG语句时,二进制日志会执行切换,上一个二进制日志文件中的GTID将会被记录到该表中,当二进制日志被丢失时,该表中的GTID记录不会丢失。
    • 如果禁用二进制记录(注释系统变量log_bin),或者禁用log_slave_updates(设置为OFF或者0),则每个事务提交时将事务的GTID一并记录到该表
  • gtid_executed变量:表示数据库中执行了哪些GTID,它是一个GTID SET处于内存中。'show slave status'中的Executed_Gtid_Set和'show master status'中的Executed_Gtid_Set都来自于它,其GTID_SET是完整的,即完整记录所有GTID。
  • gtid_purged变量:表示由于binary log文件的删除(如purge binary logfiles或者超过expire_logs_days设置)已经丢失的GTID Event,它是一个GTID SET处于内存中。我们在搭建备库的时候,通常需要使用'set global gtid_purged'命令来设置本变量,用于表示这个备份已经执行了哪些GTID操作。注意手动删除binary log将不会更新这个变量。


GTID的运维

跳过一个事务

在GTID模式下,需要跳过一个事务,那么需要获得从库执行的之后一个GTID操作,可以通过以下方法实现:

  • show slave status\G; 命令结果中的 Executed_Gtid_Set
  • show global variables like '%gtid%'; 命令结果集中的gtid_executed
  • show master status 命令结果集中的 Executed_Gtid_Set

构建一个空事务

stop slave;
set gtid_next='xxxx:34';
begin;commit;
set gtid_netx='automatic';
start slave;
复制

注意:在 GTID 模式下,传统的参数 sql_slave_skip_counter 不能使用。

mysqldump 导出行为的改变

  • 可以使用 --set-gtid-purged=OFF 选项告诉 mysqldump 不需要设置参数 SQL_LOG_BIN=0 和 gtid_purged 变量
  • 但是初始化搭建主从的时候一定不要将其设置为 OFF
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论

墨天轮福利君
暂无图片
2年前
评论
暂无图片 0
您好,您的文章已入选墨力原创作者计划合格奖,10墨值奖励已经到账请查收! ❤️我们还会实时派发您的流量收益。
2年前
暂无图片 点赞
评论