0

0

SQL GTID 复制的 executed_gtid_set 与 auto-position 机制实践

舞夢輝影

舞夢輝影

发布时间:2026-02-17 16:33:10

|

250人浏览过

|

来源于php中文网

原创

mysql 8.0中executed_gtid_set不连续会导致auto-position复制启动失败,因gtid差集无法确定同步起点;需reset slave all后重新配置auto_position=1,并确保gtid_mode与enforce_gtid_consistency均为on。

sql gtid 复制的 executed_gtid_set 与 auto-position 机制实践

MySQL 8.0 中 executed_gtid_set 不连续导致从库无法启动 auto-position

当从库的 executed_gtid_set 出现空洞(gap),比如跳过了某个 GTID 事务,START SLAVE 会直接报错 ERROR 3021 (HY000): This operation cannot be performed with a running slave 或更常见的 ERROR 1794 (HY000): The slave is not configured or failed to initialize properly —— 实际上是 GTID 自动定位失败了。

根本原因:auto-position 启用后,从库不再依赖 CHANGE MASTER TO ... MASTER_LOG_FILE/MASTER_LOG_POS,而是靠 executed_gtid_set 和主库的 gtid_executed 做差集,算出需要拉取的事务范围。一旦本地 executed_gtid_set 缺失中间 GTID,MySQL 就无法确定“从哪开始追”,干脆拒绝启动复制。

  • 检查缺口:在从库执行 SELECT * FROM performance_schema.replication_applier_status_by_coordinator;LAST_PROCESSED_TRANSACTION 是否断层;或对比 SELECT @@global.gtid_executed; 和主库的输出
  • 修复方式不是“补 GTID”,而是重置:先 STOP SLAVE;,再 RESET SLAVE ALL;(清空 relay log、master info、gtid_purged 等),然后用 CHANGE MASTER TO ... AUTO_POSITION = 1; 重新配置
  • 注意 RESET SLAVE ALL 会清除 gtid_purged,如果从库曾执行过 SET GLOBAL gtid_purged = ...,重置后需手动补回,否则主库可能拒绝发送已 purge 的事务

启用 auto-position 前必须确保主从 gtid_mode = ONenforce_gtid_consistency = ON

这两个参数不是“建议开启”,而是 auto-position 的硬性前提。只要其中任一为 OFF,即使你在 CHANGE MASTER TO 里写了 AUTO_POSITION = 1,MySQL 也会静默忽略,并退回到基于 binlog 文件名+位置的传统复制模式。

常见误操作:只改了主库,忘了从库;或者用 SET GLOBAL 临时修改,但没写进 my.cnf,重启后失效,导致某次故障恢复后复制突然“变慢”或“跳事务”——其实是退化成了 file/pos 模式,而 DBA 还以为是 GTID 在工作。

  • 确认命令:在主从两端都执行 SELECT @@gtid_mode, @@enforce_gtid_consistency;,结果必须是 ON, ON
  • 动态设置无效:这两个变量不支持运行时修改(MySQL 8.0.26 之前会报错 ERROR 1238 (HY000): Variable 'gtid_mode' is a read only variable),必须改配置文件 + 重启
  • 从库若曾用 file/pos 模式运行过,切到 GTID 前需先 STOP SLAVE;,再 RESET SLAVE; 清理旧位点,否则 AUTO_POSITION = 1 仍可能被绕过

gtid_purged 被意外覆盖导致主库拒绝提供 binlog

从库执行 RESET SLAVE ALL 或导入备份时手动设置了 gtid_purged,但值比主库当前的 gtid_executed 还大,主库就会在握手阶段直接断连,错误日志里出现 The slave tried to set gtid_purged to a value greater than the current gtid_executed on the master

Synthesys
Synthesys

Synthesys是一家领先的AI虚拟媒体平台,用户只需点击几下鼠标就可以制作专业的AI画外音和AI视频

下载

本质是主库的自我保护:它不允许从库声称“我已经执行了你还没生成的事务”。这个判断发生在 CHANGE MASTER TO ... AUTO_POSITION = 1 执行时,而不是启动复制后。

  • 安全做法:从库的 gtid_purged 应 ≤ 主库的 gtid_executed;最稳妥是让它等于主库 gtid_executed 的子集(比如用备份时记录的 Executed_Gtid_Set
  • 查主库当前值:SELECT @@global.gtid_executed;;查从库已 purge 的:SELECT @@global.gtid_purged;
  • 若已出错,不能删主库 binlog 来迁就从库;只能修正从库 gtid_purged:停从库 → SET GLOBAL gtid_purged = 'xxx-yyy:1-100';(填主库实际值的子集)→ 再 CHANGE MASTER TO ... AUTO_POSITION = 1;

mysqldump 备份恢复后从库无法 auto-position 同步

mysqldump --single-transaction --set-gtid-purged=ON 导出的 SQL 文件,默认会在开头插入类似 SET @@GLOBAL.GTID_PURGED='xxx:1-100'; 的语句。如果这个值和你实际要恢复到的主库状态不匹配(比如主库已推进到 xxx:1-150),恢复后从库的 gtid_purged 就会偏小,导致 auto-position 计算出错,复制卡在“等待第一个事务”状态,SHOW SLAVE STATUS\GRetrieved_Gtid_Set 为空,Exec_Master_Log_Pos 停在 4。

这不是数据问题,是元数据错配。很多 DBA 反复 START SLAVE 却无反应,就是因为没意识到 GTID 元信息已经锁死了同步起点。

  • 导出时加 --set-gtid-purged=OFF 可跳过注入,但恢复后必须手动 SET GLOBAL gtid_purged = '...';(用主库当前值)
  • 更推荐用 --set-gtid-purged=auto(默认),它会自动读取源实例的 gtid_executed 并写入;但前提是 dump 时连接的是你要对齐的那个主库
  • 恢复后立刻验证:SELECT @@global.gtid_purged; 必须包含主库 gtid_executed 的前缀,且不能有超出部分

GTID 复制里真正难的不是配置开关,而是所有节点的 GTID 集合必须构成一个可推导的、无歧义的偏序关系;一旦某个环节人为干预了 gtid_purged 或跳过了事务,整个自动定位逻辑就失去依据。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

965

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

334

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

377

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1696

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

371

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1252

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

436

2024.04.29

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

283

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号