標籤:mysql主從故障切換
一:環境192.168.1.100 master192.168.1.101 slave1192.168.1.102 slave2 slave1,slave2都是連在master上。 二:類比主故障關閉master執行個體service MySQL stop此時,slave1,slave2上show slave status\G都會發現錯誤:Last_IO_Error: error reconnecting to master‘[email protected]:3307‘ - retry-time: 60 retries: 1 IO進程和sql進程狀態:Slave_IO_Running: Connecting(該狀態表示會一直嘗試重連主,如果主正常了,該進程狀態會自動變成Yes)Slave_SQL_Running: Yes此時,master不能提供讀寫服務。我們想將其中最新的slave提升為主。三:切換步驟3.1確保所有的relay log全部讀取完畢在每個從庫上執行:stopslave io_thread;showprocesslist;直到看到Slave has read all relay log; waitingfor more updates,則表示從庫更新都執行完畢了或者通過show slave status查看Slave_SQL_Running_State: Slave has read allrelay log; waiting for more updates 3.2 選擇新的主庫對比選擇Relay_Master_Log_File,Exec_Master_Log_Pos最大的作為新的主庫,這裡我們選擇slave1為新的主庫其實,如果兩個從IO進程一直都是正常,沒有落後於主,且relay log都已經重放完成,兩個從是一樣的,選擇哪個都可以。這裡選擇slave1作為新主。 3.3 進行相應配置登陸slave1,執行stop slave;並進入資料庫目錄,刪除master.info和relay-log.info檔案(刪除前,可以先備份下這倆檔案);配置my.cnf檔案,開啟log-bin,如果有log-slaves-updates=1和read-only=1則要注釋掉,然後重啟slave1. 3.4 reset master在slave1上reset master,會重建二進位日誌。mysql> reset master;Query OK, 0 rows affected (0.02 sec) mysql> show binary logs;+------------------+-----------+| Log_name | File_size |+------------------+-----------+| mysql-bin.000001 | 154 |+------------------+-----------+1 row in set (0.00 sec) 3.5建立用於同步的使用者如果slave1完全同步master的話,這步可以省略。 3.6 slave2指向slave1[sql] view plain copymysql> change master to master_user=‘RepUser‘,master_password=‘beijing‘,master_host=‘192.168.1.101‘,master_port=3307,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) 3.7 將程式寫IP改成slave1的IP程式裡之前記錄的是master的IP,現在master宕機,故需改IP。
本文出自 “linux營運” 部落格,轉載請與作者聯絡!
mysql主從故障切換