欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mysql主從三種復制模式(異步復制,半同步復制,組復制)

 更新時間:2022年08月10日 17:08:27   作者:Rickyyan???????  
這篇文章主要介紹了Mysql主從三種復制模式(異步復制,半同步復制,組復制),MySQL異步復制是主從復制過程中默認的復制模式,下文簡單介紹,感興趣的朋友可以參考一下

MySQL異步復制

MySQL異步復制是主從復制過程中默認的復制模式。主從復制涉及三個線程,master I/O線程、slave I/O線程、slave sql線程。因為是異步復制,所以master事務的提交,不需要經過slave的確認,即master I/O線程提交事務后,不需要等待slave I/O線程的回復確認,master并不保證binlog一定寫入到了relay log中;而slave I/O把binlog寫入relay log后,由slave sql線程異步執(zhí)行應用到slave mysql中,slave I/O也不需要slave sql的回復確認,并不保證relay log日志完整寫入到了mysql中。

半同步復制

基于傳統(tǒng)異步存在的缺陷,mysql在5.5版本推出半同步復制,是對傳統(tǒng)異步復制的改進。在master事務commit前,必須確保binlog日志已經寫入slave 的relay log日志中,收到slave給master的響應后,才能進行事務的commit。但是后半部分的relay log到sql線程仍然屬于異步執(zhí)行。

組復制

基于傳統(tǒng)異步復制和半同步復制的缺陷——數據的一致性問題無法保證,MySQL官方在5.7.17版本正式推出組復制(MySQL Group Replication,簡稱MGR)。

由若干個節(jié)點共同組成一個復制組,一個事務的提交,必須經過組內大多數節(jié)點(N / 2 + 1)決議并通過,才能得以提交。如上圖所示,由3個節(jié)點組成一個復制組,Consensus層為一致性協(xié)議層,在事務提交過程中,發(fā)生組間通訊,由2個節(jié)點決議(certify)通過這個事務,事務才能夠最終得以提交并響應。

引入組復制,主要是為了解決傳統(tǒng)異步復制和半同步復制可能產生數據不一致的問題。組復制依靠分布式一致性協(xié)議(Paxos協(xié)議的變體),實現了分布式下數據的最終一致性,提供了真正的數據高可用方案(是否真正高可用還有待商榷)。其提供的多寫方案,給我們實現多活方案帶來了希望。

MGR環(huán)境下,服務器數量必須是3臺以上,并且是單數,實現2/n+1的算法。

一個復制組由若干個節(jié)點(數據庫實例)組成,組內各個節(jié)點維護各自的數據副本(Share Nothing),通過一致性協(xié)議實現原子消息和全局有序消息,來實現組內實例數據的一致。

MGR的解決方案現在具備的特性

數據一致性保障:確保集群中大部分節(jié)點收到日志

多節(jié)點寫入支持:多寫模式下支持集群中的所有節(jié)點都可以寫入(但是考慮1到高并發(fā)場景下,保證數據高度一致性,生產并沒有選擇多主寫入,使用單主集群)

Fault Tolerance: 確保系統(tǒng)發(fā)生故障(包括腦裂)依然可用,雙寫對系統(tǒng)無影響

MGR的解決方案目前的影響

  • 僅支持InnoDB表,并且每張表一定要有一個主鍵,用于做write set的沖突檢測;
  • 必須打開GTID特性,二進制日志格式必須設置為ROW,用于選主與write set
  • COMMIT可能會導致失敗,類似于快照事務隔離級別的失敗場景
  • 目前一個MGR集群最多支持9個節(jié)點
  • 不支持外鍵于save point特性,無法做全局間的約束檢測與部分部分回滾
  • 二進制日志不支持binlog event checksum

到此這篇關于Mysql主從三種復制模式(異步復制,半同步復制,組復制)的文章就介紹到這了,更多相關Mysql主從復制內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • MySQL刪除表的時候忽略外鍵約束的簡單實現

    MySQL刪除表的時候忽略外鍵約束的簡單實現

    下面小編就為大家?guī)硪黄狹ySQL刪除表的時候忽略外鍵約束的簡單實現。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-03-03
  • linux mysql 數據庫開啟外部訪問設置指南

    linux mysql 數據庫開啟外部訪問設置指南

    Linux下設置MySQL和允許外部機器訪問,具體目錄是具體情況而定,有的人是安裝了在個人目錄下,則找到對應的目錄則可以
    2012-11-11
  • mysql實現sequence功能的代碼

    mysql實現sequence功能的代碼

    今天小編就為大家分享一篇關于mysql實現sequence功能的代碼,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • 修改Mysql root密碼的方法

    修改Mysql root密碼的方法

    這篇文章主要介紹了修改Mysql root密碼的方法的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-11-11
  • mysql解壓縮方式安裝和徹底刪除的方法圖文詳解

    mysql解壓縮方式安裝和徹底刪除的方法圖文詳解

    這篇文章主要介紹了mysql解壓縮方式安裝和徹底刪除的方法,只有mysql徹底刪除干凈了,才可以裝另外新的版本,需要的朋友可以參考下
    2018-01-01
  • MySQL中的數據加密解密安全技術教程

    MySQL中的數據加密解密安全技術教程

    在數據庫應用程序中,數據的安全性是至關重要的,MySQL作為一種常用的關系型數據庫管理系統(tǒng),也提供了一些數據加密和解密的技巧來保護敏感數據的安全性,為了保護敏感數據免受未經授權的訪問,我們可以使用加密和解密技術
    2024-01-01
  • MySQL子查詢與HAVING/SELECT的結合使用

    MySQL子查詢與HAVING/SELECT的結合使用

    這篇文章主要介紹了MySQL子查詢在HAVING/SELECT字句中使用、及相關子查詢和WITH/EXISTS字句的使用,具有一定的參考價值,感興趣的可以了解一下
    2023-06-06
  • mysql查看表結構的三種方法總結

    mysql查看表結構的三種方法總結

    這篇文章主要介紹了mysql查看表結構的三種方法總結,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • MySQL?根據多字段查詢重復數據的示例代碼

    MySQL?根據多字段查詢重復數據的示例代碼

    本文介紹了如何使用 MySQL 根據多個字段查詢重復數據,我們介紹了如何根據多個字段查詢重復數據,并提供了相應的代碼示例,通過這些方法,我們可以快速準確地找到和處理重復數據,提高數據庫的數據質量,需要的朋友可以參考下
    2023-11-11
  • Mysql 遠程連接配置實現的兩種方法

    Mysql 遠程連接配置實現的兩種方法

    這篇文章主要介紹了Mysql 遠程連接配置實現的兩種方法的相關資料,需要的朋友可以參考下
    2017-07-07

最新評論