mysql的主從復制是如何實現的


前言

MySQL的主從復制是MySQL本身自帶的一個功能,不需要額外的第三方軟件就可以實現,其復制功能並不是copy文件來實現的,而是借助binlog日志文件里面的SQL命令實現的主從復制,可以理解為我再Master端執行了一條SQL命令,那么在Salve端同樣會執行一遍,從而達到主從復制的效果。

 

MySQL主從復制架構圖

  • 一主一從

master-slave-replication-01master-slave-replication-01

  • 一主多從

master-slave-replication-02master-slave-replication-02

  • 級聯

master-slave-replication-03master-slave-replication-03

  • 雙主一從

master-slave-replication-04master-slave-replication-04

  • 互為主從

master-slave-replication-05master-slave-replication-05

  • 環狀

master-slave-replication-06master-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的數據庫中進行執行

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM