MYSQL主從複製的搭建

君落塵發表於2015-02-25

前言:MYSQL的主從複製的原理跟MYSQL的主主複製的原理其實是一樣的,但是從資料庫不能用於寫操作,所以在配置的過程中會存在部分引數配置的一些不一樣的地方;

主主和主從複製的架構圖

主從複製的具體配置步驟如下:

一、主資料庫引數的配置

log-bin=mysql-bin

# binary logging format - mixed recommended

binlog_format=mixed //主從複製模式,混合模式(MBR)預設的

binlog_cache_size=4M //設定binlog快取大小

max_binlog_size=300M //設定binlog檔案最大體積

replicate_do_db=retail

 

二、在主資料庫上面建立通訊使用者

指令碼如下:

mysql> GRANT REPLICATION SLAVE ON *.* TO 'server01'@'%' IDENTIFIED BY 'server01';

 

三、進行主資料庫的備份

備份Master上的資料,首先執行鎖表操作,如下SQL語句:

mysql>FLUSH TABLES WITH READ LOCK; //先鎖定資料庫,等恢復完成後,再解鎖

Query OK, 0 rows affected (0.00 sec)

mysql> reset master;

Query OK, 0 rows affected (0.00 sec)

不要退出這個終端,否則這個鎖就失效了;在不退出終端的情況,再開一個終端直接打包壓縮資料檔案或使用mysqldump工具來匯出資料。

# mysqldump -uroot -p retail > /tmp/retail.sql

mysql> show master status; //檢視主伺服器binlog和Postion

*************************** 1. row **************************************

File: mysql-bin.000001

Position: 2424

Binlog_Do_DB:

Binlog_Ignore_DB:

1 row in set (0.00 sec)

 

三、設定SLAVE的引數檔案

#binlog_format=mixed

# required unique id between 1 and 2^32 - 1

# defaults to 1 if master-host is not set

# but will not function as a master if omitted

server-id= 3 //跟master區分開來

read_only=1

replicate_do_db= retail

 

四、在SLAVE資料庫上面進行恢復

建立retail資料

mysql> create database retail

 

進行資料的匯入

mysql> SOURCE /tmp/retail.sql

 

五、在SLAVE上面設定連線Master,並啟動SLAVE

mysql> CHANGE MASTER TO MASTER_HOST='192.168.47.149',MASTER_USER='server',MASTER_PASSWORD='server', MASTER_LOG_FILE='mysql-bin.000001',MASTER_LOG_POS=2424;

 

mysql> SLAVE START //啟動SLAVE服務

 

mysql> SHOW SLAVE STATUS\G; //檢查slave的連線情況

mysql> SHOW SLAVE STATUS\G

*************************** 1. row ***************************

Slave_IO_State: Waiting for master to send event

Master_Host: 192.168.47.149

Master_User: server

Master_Port: 3306

Connect_Retry: 60

Master_Log_File: mysql-bin.000001

Read_Master_Log_Pos: 2424

Relay_Log_File: mysql03-relay-bin.000002

Relay_Log_Pos: 666

Relay_Master_Log_File: mysql-bin.000001

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

Replicate_Do_DB:

Replicate_Ignore_DB:

Replicate_Do_Table:

Replicate_Ignore_Table:

Replicate_Wild_Do_Table:

Replicate_Wild_Ignore_Table:

Last_Errno: 0

Last_Error:

Skip_Counter: 0

Exec_Master_Log_Pos: 2424

Relay_Log_Space: 824

Until_Condition: None

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

以上兩個值,都為YES的時候,說明主從配置已經成功了。

 *********************************************************************************************************************

本文作者:JOHN QQ:1916066696 (請備註資料庫)

ORACLE技術部落格:
ORACLE 獵人筆記 http://blog.itpub.net/12679300/

請掃描加微訊號!

 

***********************************************************************************************************

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29819001/viewspace-1440891/,如需轉載,請註明出處,否則將追究法律責任。

相關文章