摘要:一旦使用的復制功能,就很大可能會碰到主備切換的情況。對于主備切換,如果是計劃內的操作,較為容易至少比緊急情況下容易??赡苡兄鲙焐弦寻l(fā)生的修改還沒有更新到它任何一臺備庫上的情況。假設是和的主庫。
一旦使用 MySQL 的復制功能,就很大可能會碰到主備切換的情況。也許是為了迭代升級服務器,或者是主庫出現問題時,將一臺備庫轉換成主庫,或者只是希望重新分配容量。不過出于什么原因,都需要將新主庫的信息告訴其它備庫。
對于主備切換,如果是計劃內的操作,較為容易(至少比緊急情況下容易)。只需在備庫簡單的使用 CHANGE MASTER TO 命令,并指定合適的值即可。而且大多數的值是可選的,只要指定需要改變的配置項接口。
備庫將拋棄之前的配置和中繼日志,并從新的主庫開始復制。同時,新的參數會被更新到 master.info 文件中,這樣就算重啟,備庫配置信息也不會丟失。
整個過程中最難的是獲取新主庫上合適的二進制日志位置。這樣備庫才可以從老主庫相同的邏輯位置開始復制。
把備庫提升為主庫要較為麻煩,我們把備庫提升主庫分為計劃內切換和計劃外切換兩種場景。
1 計劃內切換備庫提升為主庫,簡單來說,有以下步驟:
停止向老主庫寫入。
讓備庫追趕上主庫(可選,可以簡化后續(xù)的步驟)。
將一臺備庫配置為新主庫。
將備庫和寫操作指向新主庫,然后開啟主庫寫入。
但上面的過程中還因此著很多細節(jié)。一些場景可能依賴于復制的拓撲結構。更深入一點,下面是大多數配置需要的步驟:
停止當前主庫上的所有寫操作。如果可以,最好能將所有的客戶端程序關閉(除了復制連接)。
通過 FLUSH TABLE WITH READ LOCK 命令在主庫上停止所有活躍的寫入。也可以在主庫上設置 read_only 選項。意味著從這一刻起,禁止向老主庫做任何寫入操作。因為一旦切換的新主庫,老主庫的寫入就意味著數據丟失。要注意的是,即使設置了 read_only 也不會阻止當前已存在的事務繼續(xù)提交。因此,可以 kill 所有打開的事務,真正的結束所有寫入。
選擇一個備庫作為新的主庫,并確保它已經完全跟上主庫(例如,讓它執(zhí)行完所有從主庫獲得的中繼日志)。
確保新主庫和老主庫數據一致。
在新主庫上執(zhí)行 STOP SLAVE。
在新主庫上執(zhí)行 CHANGE MASTER TO MASTER_HOST="",然后再執(zhí)行 RESET SLAVE,使其斷開與老主庫的連接,并丟棄 master.info 里記錄的信息(如果連接信息記錄在 my.cnf 里,會無法正常工作,因此我們建議不要把復制連接信息寫到配置文件里)。
執(zhí)行 SHOW MASTER STATUS 記錄新主庫的二進制日志坐標。
確保其它備庫已經追趕上老主庫。
關閉老主庫。
將客戶端連接到新主庫。
在每臺備庫上執(zhí)行 CHANGE MASTER TO 語句,使用之前獲得的二進制日志坐標,指向新的主庫。
2 計劃外切換當主庫崩潰時,需要將一臺備庫提升為主庫。這個過程就比較麻煩。如果只有一臺備庫,可以直接使用這臺備庫。但如果有超過一臺的備庫,就需要做一些額外的工作。
另外,還有潛在的丟失復制事件的問題??赡苡兄鲙焐弦寻l(fā)生的修改還沒有更新到它任何一臺備庫上的情況。甚至可能一條語句在主庫上執(zhí)行了回滾,但在備庫上沒有回滾,這樣備庫可能就超過主庫的邏輯復制位置。如果能在某一點恢復主庫的數據,也許就可以取得丟失語句,并手動執(zhí)行他們。
在以下描述中,需要確保在服務器中使用 Master_Log_File 和 Read_Master_Log_Pos 的值。
2.1 主備結構之備庫提升確定哪臺備庫的數據最新。檢查每臺備庫上 SHOW_SLAVE_STATUS 命令的輸出,選擇其中 Master_Log_File 和 Read_Master_Log_Pos 的值最新的那個。
讓所有備庫執(zhí)行完所有從老主庫崩潰前獲得的中繼日志。
在新主庫上執(zhí)行 STOP SLAVE。
在新主庫上執(zhí)行 CHANGE MASTER TO MASTER_HOST="",然后再執(zhí)行 RESET SLAVE,使其斷開與老主庫的連接,并丟棄 master.info 里記錄的信息。
執(zhí)行 SHOW MASTER STATUS 記錄新主庫的二進制日志坐標。
比較每臺備庫和新主庫上的 Master_Log_File 和 Read_Master_Log_Pos 的值。
將客戶端連接到新主庫。
在每臺備庫上執(zhí)行 CHANGE MASTER TO 語句,使用之前獲得的二進制日志坐標,指向新的主庫。
如果已經在所有備庫上開啟了 log_bin 和 log_slave_updates,就可以將所有備庫恢復到一個一致的時間點,如果沒有開啟這兩個選項,則很難做到這一點。
上面過程中比較重要的一點是確定日志位置。接下來,我們就來看看如何卻。
3 確定日志位置如果有備庫和新主庫的位置不相同,則需要找到該備庫最后一條執(zhí)行的事件在新主庫的二進制日志中對應的位置,然后再執(zhí)行 CHANGE MASTER TO。可以通過 mysqlbinlog 工具來找到備庫執(zhí)行的最后一條查詢,然后再主庫上找到同樣的查詢,進行簡單的計算即可得到。
為了便于描述,假設每個日志事件都有一個自增數字 ID。新主庫在老主庫崩潰時獲得了編號為 100 的事件,另外兩條備庫:R2 和 R3。R2 已結獲取了 99 號事件,R3 獲取了 98 號事件。
如果把 R2 和 R3 都指向新主庫的同一個二進制日志位置,它們將從 101 號事件開始復制,從而導致數據不同步。但只要新主庫的二進制日志已結通過 log_slave_updates 打開,就可以在新主庫的二進制日志中找到 99 號 和 100 號事件,從而將備庫恢復到一致的狀態(tài)。
由于服務器重啟,不同的配置,日志輪轉或者 FLUSH LOGS 命令,同一個事件在不同的服務器上可能有不同的偏移量。我們可以通過 mysqlbinlog 從二進制日志或中繼日志中解析出每臺備庫上執(zhí)行的最后一個事件,并還有該命令解析新主庫上的二進制文件,找到相同的查詢,mysqlbinlog 會打印出該事件的偏移量,在 CHANGE MASTER TO 命令中使用這個值。
更快的方法是把新主庫和停止的備庫上的字節(jié)偏移量相減,它顯示了字節(jié)位置的差異。然后把這個值和新主庫當前二進制日志的位置相減,就可以得到期望的查詢位置。
一起來看個栗子。
假設 s1 是 s2 和 s3 的主庫。其中 s1 已經崩潰。根據 SHOW SLAVE STATUS 獲得 Master_Log_File 和 Read_Master_Log_Pos 的值,s2 已結執(zhí)行完了 s1 上所有的二進制日志,但 s3 還沒有。如圖 1:
我們可以肯定 s2 已經執(zhí)行完了主庫上的所有二進制日志,因為 Master_log_File 和 Read_Master_Log_Pos 的值和 s1 上最后的日志位置相吻合。因此,我們可以將 s2 提升為新主庫,并將 s3 設置為 s2 的備庫。
應該在 s3 上為需要執(zhí)行的 CHANGE MASTER TO 語句賦予什么參數呢?這里需要做一點計算。
s3 在偏移量 1493 處停止,比 s2 執(zhí)行的最后一條語句的偏移量 1582 要小 89 字節(jié)。
s2 正在向偏移量為 8167 的二進制日志寫入,因此,理論上我們應該將 s3 指向 s2 日志的偏移量為 8167-89=8078 的位置。
最后在 s2 日志中的 8078 位置,確定該位置上是否是正確的日志事件。
如果驗證沒問題,可以通過下面命令將 s3 切換為 s2 的備庫:
CHANGE MASTER TO MASTER_HOST="s2 host", MASTER_LOG_FILE="mysql-bin.000009", MASTER_LOG_POS=8078;
如果服務器在它崩潰時已經執(zhí)行完成并記錄了一個事件 a。因為 s2 僅僅讀取并執(zhí)行到了 1582,因此可能會失去事件 a。但是如果老主庫的磁盤沒有損壞,仍然可以通過 mysqlbinlog 或者從日志服務器的二進制日志中找到丟失的事件。
總結備庫提升區(qū)分計劃內和計劃外場景。
備庫提升,找到新主庫準確的二進制日志位置是關鍵。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://systransis.cn/yun/31263.html
摘要:一旦使用的復制功能,就很大可能會碰到主備切換的情況。對于主備切換,如果是計劃內的操作,較為容易至少比緊急情況下容易??赡苡兄鲙焐弦寻l(fā)生的修改還沒有更新到它任何一臺備庫上的情況。假設是和的主庫。 一旦使用 MySQL 的復制功能,就很大可能會碰到主備切換的情況。也許是為了迭代升級服務器,或者是主庫出現問題時,將一臺備庫轉換成主庫,或者只是希望重新分配容量。不過出于什么原因,都需要將新主庫...
摘要:問題原因非正常關機導致沒有把數據及時的寫入硬盤。丟失的臨時表臨時表和基于語句的復制方式不相容。如果備庫崩潰或者正常關閉,任何復制線程擁有的臨時表都會丟失。臨時表的特性只對創(chuàng)建臨時表的連接可見。 主備復制過程中有很大可能會出現各種問題,接下來我們就討論一些比較普遍的問題,以及當遇到這些問題時,如何解決或者預防問題發(fā)生。 1 數據損壞或丟失 問題描述:服務器崩潰、斷電、磁盤損壞、內存或網絡...
摘要:問題原因非正常關機導致沒有把數據及時的寫入硬盤。丟失的臨時表臨時表和基于語句的復制方式不相容。如果備庫崩潰或者正常關閉,任何復制線程擁有的臨時表都會丟失。臨時表的特性只對創(chuàng)建臨時表的連接可見。 主備復制過程中有很大可能會出現各種問題,接下來我們就討論一些比較普遍的問題,以及當遇到這些問題時,如何解決或者預防問題發(fā)生。 1 數據損壞或丟失 問題描述:服務器崩潰、斷電、磁盤損壞、內存或網絡...
閱讀 1282·2021-11-15 18:14
閱讀 3168·2021-08-25 09:38
閱讀 2673·2019-08-30 10:55
閱讀 2704·2019-08-29 16:39
閱讀 1316·2019-08-29 15:07
閱讀 2457·2019-08-29 14:14
閱讀 821·2019-08-29 12:36
閱讀 921·2019-08-29 11:21