MySQL的主從複製是如何?的

來源:互聯網
上載者:User

標籤:迴圈   log檔案   檔案中   src   article   步驟   連結   如何   更新   

前言

MySQL的主從複製是MySQL本身內建的一個功能,不需要額外的第三方軟體就可以實現,其複製功能並不是copy檔案來實現的,而是藉助binlog記錄檔裡面的SQL命令實現的主從複製,可以理解為我再Master端執行了一條SQL命令,那麼在Salve端同樣會執行一遍,從而達到主從複製的效果。

 

MySQL主從複製架構圖
  • 一主一從

master-slave-replication-01

  • 一主多從

master-slave-replication-02

  • 級聯

master-slave-replication-03

  • 雙主一從

master-slave-replication-04

  • 互為主從

master-slave-replication-05

  • 環狀

master-slave-replication-06

 

主從複製原理

MySQL的主從複製是一個非同步複製過程,資料庫從一個Master複製到Slave資料庫,在Master與Slave之間實現整個主從複製的過程是由三個線程參與完成的,其中有兩個線程(SQL線程和IO線程)在Slave端,另一個線程(IO線程)在Master端。

 

主從複製流程圖

 流程說明:

MySQL主從複製之前我們需要先啟動Master資料庫然後再啟動Salve資料庫,然後在Salve資料庫中執行start slave;,執行完成之後,流程就如下了:

  1. Salve的IO線程會讀取mastr.info檔案中配置好的主庫資訊,比如說存放的有:Master資料庫的使用者名稱、密碼、連接埠、還有Master的binlog索引位置;
  2. 拿到資訊之後就帶著資訊去連結Master的主庫IO線程
  3. 當主庫的IO線程先檢查SLave傳過來的配置資訊是否正確,如果正確,就拿著Slave傳過來的binlog索引位置和Master庫的binlog檔案中最後一個索引位置進行對比,如果一致就陷入等待狀態,等待Master的binlog索引位置更新;
  4. 如果不一致就把Slave傳過來的binlog索引位置往後的所有SQL語句包括最後一條SQL語句的索引位置發送個給Slave的IO線程;
  5. Slave的IO線程拿到資訊之後,先把Master傳過來的binlog索引在Slave的master.info檔案中進行更新;
  6. 然後再把Master傳過來的SQL語句寫入到relay檔案中,然後繼續迴圈執行第二個步驟;
  7. Slave的SQL線程會一直持續的觀察relay記錄檔中是否有改動,如果沒有就繼續監聽;
  8. 如果發現relay中有變動,那麼就擷取變動的內容轉換為SQL語句,並且把SQL語句在Salve的資料庫中進行執行

 

MySQL的主從複製是如何?的

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.