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