先修改Master的 my.cnf 配置mysql
在 [mysqld] 中新增如下內容sql
log-bin=mysql-bin
log-bin-index=mysql-bin.index
server-id = 1
sync_binlog=1
binlog_format=mixed數據庫
而後指定要作同步的數據庫,並忽略掉不須要作同步的數據庫服務器
binlog-do-db = testdb
binlog-ignore-db = mysql
binlog-ignore-db = performance_schema
binlog-ignore-db = information_schemaide
在 [mysqldump] 中修改內容爲
max_allowed_packet = 32M測試
注意:確保 max_allowed_packet 有比較大的值,好比 max_allowed_packet = 100M命令行
重啓 mysql
service mysql restartrest
在Master上建立一個複製用戶
CREATE USER funsion;
GRANT REPLICATION SLAVE ON *.* TO funsion IDENTIFIED BY 'ifunsion.com';
# 測試環境密碼是 xyzzy日誌
+ ---------------------------------------------------------- +orm
再修改 Slave的配置,修改 my.cnf
在 [mysqld] 中新增如下內容
server-id=2
log-bin = mysql-bin
relay-log-index = slave-relay-bin.index
relay-log = slave-relay-bin
sync_master_info = 1
sync_relay_log = 1
sync_relay_log_info = 1
# 以上三行話只使用於MySQL 5.5
輸入 mysql -u root -p
進入mysql命令行,輸入
CHANGE MASTER TO MASTER_HOST = '10.1.123.233', MASTER_USER = 'funsion', MASTER_PORT = 3306, MASTER_PASSWORD = 'ifunsion.com';
CHANGE MASTER TO MASTER_CONNECT_RETRY=30;
在輸入 START SLAVE;
+ ----------------------- 若是發生錯誤沒法啓動 ------------------- +
進入Master 的數據庫
輸入 show master status\G
記錄下當前使用的 log-bin文件,以及position (好比如今日誌是 mysql-bin.000001 ,位置是 107)
而後進入Slave 的數據庫
輸入 stop slave;
change master to master_log_file='mysql-bin.000001',master_log_pos=107;
最後輸入 start slave;
最後在服務器上執行
yum -y install ntpdate
ntpdate cn.pool.ntp.org
clock -w
把幾臺服務器的時間同步
+ ---------------------------- 一些可能用到的命令 ------------------------- +
執行鎖表:
flush tables with read lock;
這一步的目的是使咱們在製做主從的過程當中,主庫中不會有新的數據,不然會給咱們的同步設置帶來麻煩
主庫執行解鎖:
unlock tables;
reset master 命令刪除了全部的二進制日誌文件並清空了二進制日誌索引文件。
reset slave 命令刪除了Slave複製所用的全部文件,從新開始。
+ ----------------------- 其它參考文檔(未驗證)-------------------------- +
庫業務不能停的狀況下爲從庫製做鏡像:案例:服務器1號:主服務器2號:從如今因爲負載問題須要上架服務器3號一樣爲1號的從服務器。可是1號庫不能停,2號也不能停,主從同步進程也不能停(要求苛刻)。能夠這樣作:在主:mysqldump -uroot -pxxxx -h127.0.0.1 --databases db1 db2 db3 --master-data=1 > bak.sql3號服務器slave stop;以後將bak.sql導入3號從服務器slave start;3號服務器會自動從導出的那一刻的節點更新。由於--master-data=1 這個參數在導出sql文件後會在最下方加上change語句。若是--master-data=0,則不會帶有。很是的方便,但僅適合庫不是太大的狀況,該案例導出的庫一共6G。