前言
MySQL的主從復制是MySQL本身自帶的一個功能,不需要額外的第三方軟件就可以實現,其復制功能並不是copy文件來實現的,而是借助binlog日志文件里面的SQL命令實現的主從復制,可以理解為我再Master端執行了一條SQL命令,那么在Salve端同樣會執行一遍,從而達到主從復制的效果。
MySQL主從復制架構圖
- 一主一從
- 一主多從
- 級聯
- 雙主一從
- 互為主從
- 環狀
主從復制原理
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的數據庫中進行執行






