測試系統:centos6.5系統
測試環境IP地址划分:
master: 192.168.80.130
slave:192.168.80.143
slave:192.168.80.146
首先模擬(MySQL---master)宕機:
service mysqld stop
當master宕機后去slave去查看是否出現錯誤信息
show slave status\G;
這時兩台SLAVE主機已經連接不上MASTER
IO進程和sql進程狀態:
Slave_IO_Running: Connecting(該狀態表示會一直嘗試重連主,如果主正常了,該進程狀態會自動變成Yes)
Slave_SQL_Running: Yes
此時,master不能提供讀寫服務。我們想將其中最新的slave提升為主。
具體操作步驟如下:
1、在每個SLAVE庫上執行:
stop slave io_thread;
show processlist;
直到看到Slave has read all relay log; waitingfor more updates,則表示從庫更新都執行完畢了
2、 選擇新的主庫
對比選擇Relay_Master_Log_File,Exec_Master_Log_Pos最大的作為新的主庫,這里我們選擇slave1為新的主庫
其實,如果兩個從IO進程一直都是正常,沒有落后於主,且relay log都已經重放完成,兩個從是一樣的,選擇哪個都可以。
這里選擇slave1作為新主。
3、進行相應配置
登陸slave1,執行stop slave;
並進入數據庫目錄,刪除master.info和relay-log.info文件(刪除前,可以先備份下這倆文件);
配置my.cnf文件,開啟log-bin,如果有log-slaves-updates=1和read-only=1則要注釋掉,然后重啟slave1.
4、 reset master
在slave1上reset master,會重新生成二進制日志。
mysql> reset master;
Query OK, 0 rows affected (0.02 sec)
mysql> show master status;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-log.000001 | 399 | | |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)
5、創建用於同步的用戶
如果slave1完全同步master的話,這步可以省略。
6、 slave2指向slave1
mysql> change master to master_user='RepUser',master_password='beijing',master_host='192.168.80.134',master_port=3306,master_log_file='mysql-bin.000001',master_log_pos=154; Query OK, 0 rows affected, 2 warnings (0.00 sec) mysql> start slave; Query OK, 0 rows affected (0.00 sec)
7、 將程序寫IP改成slave1的IP
程序里之前記錄的是master的IP,現在master宕機,故需改IP。