先修改Master(192.168.1.197)的 my.cnf 配置 在 [mysqld] 中新增如下內容 log-bin = mysql-bin log-bin-index = mysql-bin.index server-id = 1 sync_binlog = 1 binlog_format = mixed 而後指定要作同步的數據庫,並忽略掉不須要作同步的數據庫 binlog-do-db = test_db binlog-ignore-db = mysql binlog-ignore-db = performance_schema binlog-ignore-db = information_schema 在 [mysqldump] 中修改內容爲 max_allowed_packet = 32M 注意:確保 max_allowed_packet 有比較大的值,好比 max_allowed_packet = 100M 重啓 mysql service mysql restart 在Master上建立一個複製用戶 CREATE USER repl_user; GRANT REPLICATION SLAVE ON *.* TO repl_user IDENTIFIED BY '123456'; + ---------------------------------------------------------- + 再修改 Slave(192.168.1.160)的配置,修改 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 = '192.168.1.233', MASTER_USER = 'repl_user', MASTER_PORT = 3306, MASTER_PASSWORD = '123456'; 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 > backup.sql 3號服務器
slave stop; 以後將backup.sql導入3號從服務器 slave start; 3號服務器會自動從導出的那一刻的節點更新。 由於 --master-data=1 這個參數在導出sql文件後會在最下方加上change語句。若是 --master-data=0 則不會帶有。 很是的方便,但僅適合庫不是太大的狀況,該案例導出的庫一共6G。