说GTID - GTID的生命周期
admin
2023-04-16 10:41:53
0

1.事务提交时会获取到一个GTID,该GTID将位于事务前面一同被记录到二进制日志中。若事务不被记录到二进制日志中,它也不会获取到GTID。


2.事务的GTID会以Gtid_log_event的形式记录到二进制日志,当二进制日志轮换或实例关闭时,MySQL会将所有已写入二进制日志的事务的GTID刷新到系统表mysql.gtid_executed。


3.事务提交后,极短时间内其GTID会被加入到一个GTID集合中(注意该过程不具有原子性),即全局系统变量gtid_executed,它代表全部已提交了的事务的GTID。在复制关系中,它也表明了该从实例已执行过哪些事务,主节点会据此判断还需发送哪些GTID。


4.当二进制日志传送到从节点转储为中继日志后,从节点会读取GTID,在会话级别将该GTID赋值给会话系统变量gtid_next,这也就告诉了从节点接下来要执行的事务的GTID是什么。


5.从节点会确认会话系统变量gtid_next中的GTID没被占用,然后为其分配一个线程,并使用全局系统变量gtid_owned(@@GLOBAL.gtid_owned)标识出该GTID和使用它的线程的ID。若该GTID已被使用,就忽略该事务。


6.若此GTID没被使用,从节点会回放该事务。从节点会使用会话系统变量gtid_next中的GTID,作为该事务的GTID,而不会为其重新生成GTID。


7.若从节点开启了二进制日志,该GTID会以Gtid_log_event的形式和事务一同记录进二进制日志。当二进制日志轮换或实例关闭时,所有已提交事务的GTID又会被刷新到系统表mysql.gtid_executed(同2)。


8.若从节点没开启二进制日志,MySQL会将回放该事务和将其GTID直接写入系统表mysql.gtid_executed作为一个事务进行,但在MySQL 5.7版本这还仅限于DML语句,在8.0版本,DDL也可以了。


9.当事务在从节点回放后,从节点上全局系统变量gtid_executed的变化同3。


相关内容

热门资讯

凤凰连线:中美新一轮经贸磋商,... 中美双方将在韩国举行第七轮经贸磋商。美方的阵容和日程安排如何?在这轮磋商中有哪些关切?凤凰卫视驻韩国...
知情人士:阿联酋秘密打击伊朗,... 据参考消息援引美国《华尔街日报》网站5月11日报道,多名知情人士透露,阿联酋已对伊朗发动军事打击,令...
美防长称美伊停火协议依然有效 △赫格塞思(资料图)当地时间5月12日,美国国防部长赫格塞思表示,他们针对伊朗问题的所有情况都制定了...
特朗普二度来华,五大博弈看点,... 就在5月11日,外交部官宣了一则重磅消息:应中国邀请,美国总统特朗普将于5月13日至15日开启访华行...
科学家预测:“哥斯拉级”厄尔尼... 科学家近日发出警告,太平洋上空正在形成一种被称为“哥斯拉”级的罕见厄尔尼诺气候模式。有科学家预测,这...
200亿美金估值的可灵,值母公... 文 | 影子备忘录 要说今年科技圈最火的赛道,AI短剧绝对排得上号。一部AI仿真人短剧,3人团队、...
多名中国公民在越南乘机遗失财物... 近日,多名中国公民反映在越乘机过程中财物遗失,中国驻胡志明市总领馆提醒中国公民注意:一、强化防范意识...
电视机尺寸一览表70寸长宽 电视机尺寸一览表70寸长宽:一般液晶电视显示屏都是16比9,70寸就是说客它对角线长70寸是106....
东莞一社区推出生育奖励方案,二... 极目新闻记者 柳之萌近日,广东东莞万江街道谷涌社区出台生育奖励方案,对符合条件的二孩家庭一次性奖励1...
80寸液晶电视尺寸长宽多少厘米 80寸液晶电视尺寸长宽多少厘米:80寸的液晶电视大概为181x111厘米,即长度大概在181厘米,宽...