简单概括主库上 Executed_Gtid_Set 是什么时候更新的

主库 上,Executed_Gtid_Set 是在本地事务 commit 成功后 才更新到 @@GLOBAL.gtid_executed 里的,不是"binlog 刚写完"就对外可见。

按主库事务链路看:

  1. 事务执行
  2. 分配 GTID
  3. commit 阶段写 binlog,Gtid_log_event 写在事务事件前面
  4. binlog 持久化
  5. 存储引擎提交成功
  6. GTID 加入主库的 @@GLOBAL.gtid_executed
  7. SHOW MASTER STATUS / SHOW REPLICA STATUS 看到的 Executed_Gtid_Set 才包含它

结合半同步:

  • after_sync 下,主库是 binlog 已刷盘、事务已发给从库并等 ACK 后,才提交存储引擎 。所以在等待 ACK 的阶段,这个事务虽然已经在主库 binlog 里,也可能已经在从库 relay log 里,但主库本地还没 commit,理论上还不应该出现在主库 Executed_Gtid_Set
  • after_commit 下,主库先提交存储引擎,再等从库 ACK;因此主库 commit 完后,Executed_Gtid_Set 很快会包含该 GTID,即使半同步 ACK 还没回来。

一句话:主库的 Executed_Gtid_Set 表示"主库已经提交过的 GTID",不是"主库 binlog 已写过的 GTID",也不是"从库已收到的 GTID"。

另一个细节:mysql.gtid_executed 表和 @@GLOBAL.gtid_executed 不完全等价。主库开启 binlog 时,完整实时状态看 @@GLOBAL.gtid_executed / SHOW MASTER STATUS,不要只看 mysql.gtid_executed 表;表里的内容可能要到 binlog rotate、shutdown,或特定版本/引擎路径下才补齐。

相关推荐
要开心吖ZSH2 小时前
Java事务与MySQL事务的关系及MVCC通俗解析
java·开发语言·mysql·mvcc
火星校尉2 小时前
一场数据基建与消费场景的跨界实验
java·前端·数据库·python·php
平安的平安2 小时前
从“云端排队“到“边缘上岗“:DolphinDB 云边协同如何重塑工业现场的实时智能
数据库
懒鸟一枚2 小时前
为什么 useradd -rs /bin/false service 创建的用户无法用 su 切换?
linux·服务器·数据库
爱喝热水的呀哈喽2 小时前
hypermesh两个网格参数解析
服务器·数据库·mysql
万亿少女的梦1682 小时前
基于Spring Boot的楚雄旅游景区门票售卖系统设计与实现
java·spring boot·mysql·vue·系统设计
IvorySQL3 小时前
PG 技术日报|2026-07-03
数据库·postgresql·开源
_Jonas3 小时前
Python SqlAlchemy对数据库各种操作整理(MySQL为例)
数据库·python·mysql
长孙豪翔3 小时前
引发事件的问题
java·linux·数据库