先修改Master(10.1.123.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 = testdb 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 funsion; GRANT REPLICATION SLAVE ON *.* TO funsion IDENTIFIED BY 'ifunsion.com'; # 測試環境密碼是 xyzzy + ---------------------------------------------------------- + 再修改 Slave(10.1.123.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 = '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.sql 3號服務器slave stop; 之後將bak.sql導入3號從服務器 slave start; 3號服務器會自動從導出的那一刻的節點更新。 因為--master-data=1 這個參數在導出sql文件後會在最下方加上change語句。如果--master-data=0,則不會帶有。 非常的方便,但僅適合庫不是太大的情況,該案例導出的庫一共6G。
--主機開兩個窗口,一個進入mysql,一個是shell
--主機阻斷寫操作
mysql> FLUSH TABLES WITH READ LOCK;
Query OK, 0 rows affected (0.00 sec)
mysql>
mysql>
mysql> SHOW MASTER STATUS;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000002 | 1529881 | openser | mysql,test |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)
--另外一個窗口導出主機數據庫
mysqldump -u root -p123456 --opt -R openser > openser20121203.sql
--剛才的窗口主機解鎖
mysql> UNLOCK TABLES;
Query OK, 0 rows affected (0.00 sec)
mysql>
--打包數據文件到從機
drop database openser;
create database openser;
mysql -u root -p123456 openser < openser20121127.sql
--從機操作
SLAVE STOP;
reset slave;
CHANGE MASTER TO MASTER_HOST='192.168.21.26',
MASTER_USER='repl_user',
MASTER_PASSWORD='123456',
MASTER_LOG_FILE='mysql-bin.000002',
MASTER_LOG_POS=1529881;
start slave;
show slave status\G
開啟之後多久就不能再同步了?不能同步的時候是哪個 running 線程編程no,從庫的err日志中是否出現更新??有更新的錯誤提示是什麼
請逐一補充