MySQL主從宕機的解決方法


測試系統: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。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM