MySQL主從複製的搭建

來源:互聯網
上載者:User

MySQL主從複製的搭建

前言: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的時候,說明主從配置已經成功了。

Ubuntu下Nginx做負載實現高效能WEB伺服器5---MySQL主主同步

生產環境MySQL主主同步主鍵衝突處理

MySQL主從失敗 錯誤Got fatal error 1236

MySQL主從複製,單台伺服器上實施

搭建MySQLProxy 伺服器實現讀寫分離+主從同步

MySQL 5.5 主從雙向同步

MySQL 5.5主從同步排錯

MySQL主從複製非同步半同步執行個體

本文永久更新連結地址:

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.