天天看點

MySQL Replication主從複制—(執行個體)

主從複制原理

MySQL Replication是一個從Master複制到一台或多台Slave的異步複制過程。

Master和Slave之間實作整個複制過程主要由三個線程來完成,其中一個IO線程在Master端,兩個線程(SQL線程和IO線程)在Slave端。

通過Master伺服器打開Binary Log(二進制日志檔案)的功能,Slave端從Master端擷取該日志資訊,然後将二進制檔案解析為SQL語句,并完全順序地執行SQL語句所記錄的各種操作。(Slave擷取到的二進制檔案同時也會寫入到自身的Relay Log檔案中)

Replication概念

MySQL Replication技術是一個日志複制過程,在複制過程中一台伺服器充當主,一台或多台其他伺服器充當從伺服器;

從伺服器到主伺服器拉取二進制日志檔案,将日志檔案解析成相應的SQL語句,然後在從伺服器上重新執行一遍主伺服器的操作,通過這種方式保證資料的一緻性。

主從複制配置步驟:

設定server-id(伺服器辨別,在一組主從中不能重複)

開啟二進制日志并指定二進制日志檔案儲存的路徑

記錄bin-log檔案和bin-log(position)位置

若不停在Master時,加入全局鎖,将需要同步的資料庫備份到Slave節點上,解除全局鎖

建立用于同步複制的使用者

使用change master 在Slave和Master建立連接配接(Slave節點設定主伺服器)

啟動Slave

檢查Slave的狀态

Step1:配置master和slave的/etc/my.cnf檔案

Step2:手動同步資料庫到slave

1、鎖定Master的表的寫操作(不要退出終端)

2、Master上備份資料庫并傳到Slave上

3、Slave上建立同步的資料庫并導入資料檔案

Step3:Master建立同步的使用者

1、Master解除鎖定

2、建立同步使用者

Step4:Slave連接配接Master,将node1設定為自己的主伺服器

1、檢視Master的master-log-file檔案和position位置

2、Slave上連接配接Master,并啟動slave

3、Slave上檢視slave狀态(Slave_IO_Running、Slave_SQL_Running和Seconds_Behind_Master)

Step5:測試主從同步功能

1、Master上建立資料庫和表

2、Slave上檢視是否同步

本文轉自 HMLinux 51CTO部落格,原文連結:http://blog.51cto.com/7424593/1752364