標籤:
先修改Master(192.168.1.197)的 my.cnf 配置在 [mysqld] 中新增以下內容log-bin = mysql-binlog-bin-index = mysql-bin.indexserver-id = 1sync_binlog = 1binlog_format = mixed然後指定要做同步的資料庫,並忽略掉不需要做同步的資料庫binlog-do-db = test_dbbinlog-ignore-db = mysqlbinlog-ignore-db = performance_schemabinlog-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=2log-bin = mysql-binrelay-log-index = slave-relay-bin.indexrelay-log = slave-relay-binsync_master_info = 1sync_relay_log = 1sync_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 ntpdatentpdate cn.pool.ntp.orgclock -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.sql3號伺服器
slave stop;之後將backup.sql匯入3號從伺服器slave start;3號伺服器會自動從匯出的那一刻的節點更新。因為 --master-data=1 這個參數在匯出sql檔案後會在最下方加上change語句。如果 --master-data=0 則不會帶有。非常的方便,但僅適合庫不是太大的情況,該案例匯出的庫一共6G。
MySQL主從同步