有時候MySQL主從同步不一致比較嚴重的時候,需要手動同步。
然而網上看大很多需要鎖表的同步的方法基本如下
1.先對主庫鎖表
FLUSH TABLES WITH READ LOCK;
2.備份數據
mysqldump -uroot -p -hlocalhost > mysql.bak.sql
3.解鎖主庫
unlock tables;
4.查看主庫的binlog文件和位置
show master status; 找出File和Position
5.使用scp命令把文件移動到從庫
scp mysql.bak.sql root@192.168.128.101:/tmp/
6.在從庫上停止同步
mysql> stop slave;
7.導入數據
mysql> source /tmp/mysql.bak.sql
8.設置從庫的同步開始文件和開始位置
change master to master_host = '主庫主機', master_user = '同步用戶名', master_port=3306, master_password='', master_log_file = '第3步中獲取的file', master_log_pos=第3步中獲取的position;
9.從庫上啟動同步並檢查
mysql> start slave;
mysql> show slave status\G 查看:
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
上網查了下,有外國友人說不需要鎖表的方法。 大致是不需要執行第1和第3步,在第2導出數據的時候加上參數
mysqldump --skip-lock-tables --single-transaction --flush-logs --hex-blob --master-data=2 -A
--skip-lock-tables 不鎖表
--master-data=2 在導出的時候同時生成binlog文件名和位置在導出的文件開頭。這個很重要。因此第4步也不需要執行了,binlog的文件和位置可以從這里拿到。
--single-transaction 通過將導出操作封裝在一個事務內來使得導出的數據是一個一致性快照
其他參數意義可以看這里:http://www.penglixun.com/tech/database/the_process_of_mysqldump.html(有翻譯)
最后把第8步的binlog文件和位置替換成導出的文件開頭找到的那個帶有注釋的file和position就好了。
轉載並總結自:http://plusbryan.com/mysql-replication-without-downtime 但也不保證100%一絲不漏的同步過來。 不過也請熟悉這方面的朋友發表下看法。