91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

說GTID - 與GTID相關的系統變量

發布時間:2020-06-06 05:51:45 來源:網絡 閱讀:464 作者:coveringindex 欄目:MySQL數據庫

gtid_next


默認事務提交時,MySQL會為其生成一個GTID。當事務在Slave節點上回放時,使用的卻是該事務在Master節點上產生的GTID,究其緣由和一個會話級系統變量gtid_next有關。


若gtid_next的值為AUTOMATIC(其默認值),當啟用二進制日志,無論在Slave節點還是Master節點上,事務提交都會產生新的GTID。但若將gtid_next賦值一個有效的GTID,那么該GTID就是接下來提交的事務的GTID,同時該GTID會被添加到GTID集合gtid_executed。Slave節點上的回放線程正式利用了這一點,把在Master節點上生成的GTID賦值給@@SESSION.gtid_next,繼而將此GTID原封不動的保存在了Slave節點上。



gtid_purged


全局系統變量gtid_purged代表了所有已經提交了,但在二進制日志中又清除掉了的事務的GTID集合。


全局系統變量gtid_purged是gtid_executed的子集合,如下情形會引起gtid_purged集合的變化:

·Slave節點上禁用了二進制日志,隨著回放線程提交復制過來的事務,gtid_purged會發生變化。

·二進制日志文件被清除時,gtid_purged會發生變化。

·@@GLOBAL.gtid_purged被賦值時,gtid_purged會發生變化。


可以通過改變gtid_purged集合,來表明該事務已提交了,但在二進制日志文件中被清除掉了。當向gtid_purged集合添加GTID時,同時也會向gtid_executed集合添加此GTID。通過備份增加一個只讀實例,正是利用的該思路。在MySQL 5.7版本,只能在gtid_executed集合為空時,才能設置gtid_purged。



每個二進制日志文件頭部都記錄了一個Previous_gtids_log_event事件,它代表了該二進制日志文件之前所有二進制日志文件中GTID的集合(即,第N個二進制日志文件中的Previous_gtids_log_event,等于第N-1個二進制日志文件中的Previous_gtids_log_event,和第N-1的文件中所有Gtid_log_event的并集)。


gtid_executed和gtid_purged這兩個全局系統變量,在MySQL啟動時就是通過最老的,和最新的二進制日志文件中的Previous_gtids_log_event和Gtid_log_event被初始化的。


gtid_executed集合被初始化的過程如下:


gtid_executed = 最新的二進制日志文件中的Previous_gtids_log_event + 最新的二進制日志文件中所有的Gtid_log_event + 系統表mysql.gtid_executed中的GTID(但該GTID集合不包含正在執行著的GTID,即@@GLOBAL.gtid_owned)。



gtid_purged集合被初始化的思路是這樣的:


第一個等式:

現存(存在)的二進制日志文件中的GTID,和被清除掉的二進制日志文件中的GTID的并集,即gtids_in_binlog。


gtids_in_binlog = 最新的二進制日志文件中的Previous_gtids_log_event + 最新的二進制日志文件中所有的Gtid_log_event


第二個等式:

現存(存在)的二進制日志文件中的GTID,即gtids_in_binlog_not_purged。


gtids_in_binlog_not_purged = gtids_in_binlog - 最老的二進制日志文件中的Previous_gtids_log_event


第三個等式:

曾經出現過,但現在已不存在于二進制日志文件中的GTID,即gtid_purged。


gtid_purged = gtid_executed - gtids_in_binlog_not_purged



通過這3個等式可得到:

gtid_purged = gtid_executed - gtids_in_binlog_not_purged = 最新的二進制日志文件中的Previous_gtids_log_event + 最新的二進制日志文件中所有的Gtid_log_event + 系統表mysql.gtid_executed中的GTID - ((最新的二進制日志文件中的Previous_gtids_log_event + 最新的二進制日志文件中所有的Gtid_log_event) - 最老的二進制日志文件中的Previous_gtids_log_event)


即,gtid_purged = 系統表mysql.gtid_executed中的GTID + 最老的二進制日志文件中的Previous_gtids_log_event



與上邊兩個全局系統變量初始化相關的一個系統參數是binlog_gtid_simple_recovery,若其值為FALSE,在初始化該兩個變量時,MySQL會遍歷所有的二進制日志文件,而不僅是最老的,和最新的二進制日志文件,此過程可能會花費較長的時間。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

铜川市| 永登县| 隆昌县| 永和县| 小金县| 泉州市| 岢岚县| 临泽县| 静安区| 平谷区| 四会市| 张北县| 湘阴县| 安新县| 漳浦县| 台湾省| 珲春市| 甘谷县| 称多县| 体育| 昌黎县| 安徽省| 望城县| 精河县| 正蓝旗| 临海市| 青岛市| 广昌县| 宿松县| 阿拉善右旗| 新建县| 苏尼特右旗| 牙克石市| 德格县| 砀山县| 新源县| 汝南县| 集安市| 衡阳县| 新宾| 遵义县|