mysql滾動查詢數(shù)據(jù),如何看待MySQL發(fā)布的GroupReplication?
背景
為獲得最佳兼容性和性能,組的所有成員為了 Group Replication,應(yīng)運行相同版本的 MySQL Server。但是,在某些情況下,可能需要組內(nèi)有不同版本的服務(wù)器運行共存。例如,在滾動升級期間。當(dāng)組中存在不同的版本時,某些成員可能與其他成員不兼容,因為它們支持其他人沒有或缺乏其他人所具有的功能。因此,組復(fù)制需實現(xiàn)兼容性策略以防止運行到不兼容的版本組合方案。在 MySQL 8.0.17 中,組復(fù)制為組中的成員版本實現(xiàn)的兼容性策略考慮了成員的 MySQL Server 版本的補丁版本。
以前,只考慮過主要版本。使用維護版本(8.0.17)意味著組復(fù)制可以在組重新配置和升級過程中更好地維護混合版本組的復(fù)制安全性。
內(nèi)容大綱
1. 主成員選項
A.主成員選舉算法具有 8.0.17 或更高版本成員的組具有至少一個 8.0.16 或更低成員版本的組B.用戶觸發(fā)主切換具有 8.0.17 或更高版本成員的組具有至少一個 8.0.16 或更低成員版本的組2. 寫版本兼容性3. 最低版本兼容性4. 捐贈者版本兼容性5. 升級6. 結(jié)論主成員選項選擇新的主節(jié)點時的參數(shù)之一是用于復(fù)制安全性的成員版本。從 8.0.17 開始,在選擇新主時也考慮補丁級別。因此,基于組配置的下一個主要內(nèi)容存在細(xì)微差別。主成員選舉算法在主成員的故障轉(zhuǎn)移期間,基于以下算法選擇新的主成員:具有 8.0.17 或更高版本成員的組該組中的所有成員都具有 8.0.17 或更高版本。1. 該組的最低成員版本,包括補丁級別2. 根據(jù)步驟-1,該組中版本最低成員的成員權(quán)重較高3. 服務(wù)器 uuid 的詞法排序在相同成員權(quán)重的組內(nèi)是最低的例子例1:主成員退出后的小組:8.0.19 / 8.0.20 / 8.0.208.0.19 將因其最低版本,開始被選為主服務(wù)器。例2:主成員退出后的小組:8.0.19 權(quán)重:90 / 8.0.19 權(quán)重:50 / 8.0.20 權(quán)重:90 / 8.0.20 權(quán)重:95“版本 8.0.19 權(quán)重:90”的服務(wù)器將被選為主要服務(wù)器,因為它是組內(nèi)的最低版本且有較高的權(quán)重。例3:主成員退出后的小組:8.0.19 權(quán)重:90 uuid:5a5d0f6e-6ad1-11e7-9aee-f48c5048ab0c8.0.19 權(quán)重:90 uuid:5a67adc9-6ad1-11e7-9b1f-f48c5048ab0c8.0.19 權(quán)重:50 uuid:5a6e5078-6ad1-11e7-9bce-f48c5048ab0c“8.0.19 權(quán)重:90 uuid:5a5d0f6e-6ad1-11e7-9aee-f48c5048ab0c”的服務(wù)器將被選為主,因為其具有較高成員權(quán)重和最低服務(wù)器 uuid。具有至少一個 8.0.16 或更低成員版本的組該組中至少有 1 名成員,版本低于 8.0.17。1. 考慮主要版本的該組的最低成員版本2. 根據(jù)步驟-1,該組中最低成員的成員權(quán)重較高3. 服務(wù)器 uuid 的詞法排序在相同成員權(quán)重的組內(nèi)是最低的例子例1:主成員退出后的小組:5.7.22 / 8.0.20 / 8.0.205.7.22 版本的服務(wù)器將從其最低版本的組中被選為主服務(wù)器。用戶觸發(fā)主切換如果主成員被修改為使用UDF,group_replication_set_as_primary(server_uuid)或 group_replication_switch_to_single_primary_mode([server_uuid]),則還會采取一些預(yù)防措施以確保所有成員兼容并可以執(zhí)行所需的更改。算法如下:具有 8.0.17 或更高版本成員的組該組中的所有成員都具有 8.0.17 或更高版本。1. 如果提供了 server_uuid,則該服務(wù)器將成為主成員,如果其版本在組中最低(考慮補丁級別),否則將引發(fā)錯誤。2. 如果未提供 server_uuid,則考慮組成員版本直到補丁級別進行選舉。例子例1:多主模式到單主模式切換時的組成員:8.0.19 權(quán)重:50 / 8.0.20 權(quán)重:90 / 8.0.20 權(quán)重:95“版本 8.0.19 權(quán)重:50”的服務(wù)器將被選為主服務(wù)器,因為它的補丁是該組的最低版本。具有至少一個 8.0.16 或更低成員版本的組該組中至少有 1 名成員,版本低于8.0.17。1. 如果組中的任何成員的版本為 5.7 或版本低于 8.0.13,則該函數(shù)不會對主成員進行任何更改。2. 如果主要版本 8 提供的 server_uuid,那么該服務(wù)器將成為主成員,否則將拋出錯誤。3. 如果未提供 server_uuid,則考慮到組成員版本的唯一主版本,將進行選舉。注意:對于 UDF group_replication_set_as_primary,server_uuid 是必需的。如果未提供 server_uuid,UDF 將失敗。例子例1:多主模式到單主模式切換時的組成員:8.0.14 權(quán)重:90 / 8.0.20 權(quán)重:50 / 8.0.20 權(quán)重:90 / 8.0.20 權(quán)重:95“版本 8.0.20 權(quán)重:95”的服務(wù)器將被選為主服務(wù)器,因為該組的最低主要版本(由于組中存在 8.0.14 而忽略了維護版本)。寫版本兼容性從 8.0.17 開始,如果新成員版本高于組的最低成員版本(考慮補丁級別),則新成員將處于只讀模式。如果該組通過執(zhí)行 UDF group_replication_switch_to_multi_primary_mode 進入多主模式,則該組的最低成員版本將是可寫的,而其他成員將處于只讀狀態(tài)。版本為 8.0.16 或更低版本的成員,如果組中的任何成員具有 5.7 版本,則以只讀模式加入組。版本 5.7 的成員始終可寫,因為 5.7 僅考慮主要版本。在 MySQL 5.7 和 8.0 中,直到補丁級別 16,當(dāng)?shù)桶姹境蓡T離開組時,用戶必須手動重新配置只讀模式。注意:這僅適用于多主模式。例子例1:多主模式的組成員:8.0.19 / 8.0.20版本 8.0.19 的服務(wù)器將是可寫的,而 8.0.20 將是只讀的。例2:組成員在單主模式到多主模式切換期間:8.0.19(主)/ 8.0.19(副)/ 8.0.20(副)/ 8.0.21(副)版本 8.0.19 的服務(wù)器將是可寫的,而 8.0.20 和 8.0.21 將是只讀的多主模式開關(guān)。例3:多主模式的組成員:5.7.21 / 8.0.15版本為 5.7.21 的服務(wù)器是可寫的,而 8.0.15 將是只讀的。例4:組成員在單主模式到多主模式切換期間:8.0.14(副)/ 8.0.15(副)/ 8.0.20(副)/ 8.0.21(主)版本 8.0.14 和 8.0.15 的服務(wù)器是可寫的(舊版本),而 8.0.20 和 8.0.21 將是只讀的。Server 8.0.21 將啟用只讀模式。最低版本兼容性從 8.0.17 開始,如果新成員版本低于該組的最低成員版本(考慮補丁級別),則新成員將不加入該組。版本 5.7 的成員無法加入僅包含 8.0+ 成員的組。8.0.16 或更低版本的成員可以加入任何組,因為它只考慮主要版本。例子例1:小組成員:8.0.19 / 8.0.20 / 8.0.20版本為 8.0.17 或 8.0.18 的服務(wù)器將無法加入該組。例2:小組成員:8.0.15 / 8.0.16版本為 5.7.27 的服務(wù)器將無法加入該組。捐贈者版本兼容性從 8.0.17 開始,在形成可能的捐贈者組列表的同時,具有與新成員相同或更低版本的 ONLINE 成員被視為有效捐贈者。但是,如果設(shè)置了 allow_local_lower_version_join,則該組的所有 ONLINE 成員都可以充當(dāng)有效的捐贈者,因為沒有相同或更低版本的成員。5.7 級別或 MySQL 8.0 至 8.0.16 的組復(fù)制版本將所有 ONLINE 成員視為恢復(fù)的主動捐助者。例子例1:組成員:5.7.22 / 8.0.20 / 8.0.21新成員 8.0.20 可以使用 5.7.22 或 8.0.20 作為捐贈者。例2:組成員:5.7.22 / 8.0.20 / 8.0.21新成員 5.7.22 可以使用 5.7.22, 8.0.20 或 8.0.20 作為捐贈者。升級對于單主升級,用戶可以先更新每個副成員,然后再更新主成員。以后的用戶可以使用 UDF group_replication_set_as_primary 使所需的成員成為主成員?;蛘哂脩艨梢詫⒏叩某蓡T權(quán)重分配給所需的成員和升級組,首先升級所需的主成員。對于多主升級,可以按任何順序升級成員。在完成組升級的過程中,由于版本較高,升級后的成員將處于只讀模式。一旦該組的所有成員升級到相同的補丁級別,所有成員都將變?yōu)榭蓪憽jP(guān)于不期望升級的一些注意事項:如果其版本低于該組的最低成員版本,則成員將不會加入該組(考慮補丁級別)° 如果升級后,版本不會是相同的補丁級別,則應(yīng)首先啟動新的最低成員版本。如果組中的所有成員的版本都大于 8.0.16,則只有當(dāng)成員是組中的最低版本(包括修補程序級別)時,才允許該成員成為主要成員?!?如果主要升級后必須保持相同的升級,則主要升級(包括補丁級別)可能不會通過此 WL。應(yīng)將組的輔助成員升級到高于或等于主要成員版本的版本。例子例1(單主升級)M1:8.0.20(舊主)/ M2:8.0.20(新主)/ M3:8.0.201. DBA 希望將所有組成員升級到 8.0.212. 在 M2 上設(shè)置更高的成員權(quán)重并升級 M2 3. 立即升級 M3 和 M14. M1 和 M3 升級后, M2 將成為主要例2(單主升級)M1:8.0.20(主)/ M2:8.0.20 / M3:8.0.201. DBA 希望將所有組成員升級到 8.0.212. 將 M2 和 M3 升級到 8.0.21 或更高版本3. 在 M2 和 M3 升級后,M1 可以升級到 8.0.214. 使用 UDF group_replication_set_as_primary M1 可以成為主例3:(多主升級)M1:8.0.20 / M2:8.0.201. DBA 希望將所有組成員升級到 8.0.212. 升級 M13. M1 升級后,M1 將是只讀的,直到 M2 升級到 8.0.214. 一旦 M2 升級到 8.0.21,M1 將變?yōu)榭蓪懡Y(jié)論MySQL 8.0.17 是公開可用的,隨之而來的是對組復(fù)制的改進?,F(xiàn)在,組復(fù)制可以增加安全性,并確保成員生成的事務(wù)與組中的每個成員兼容。