MySQL Slave異常關機的處理 (pt-slave-restart)

來源:互聯網
上載者:User

MySQL Slave異常關機的處理 (pt-slave-restart)

MySQL Slave異常關機的處理除了後面的三個方法。
還可以使用percona-toolkit的pt-slave-restart命令。

percona-toolkit-2.2.8-1.noarch.rpm 需要安裝一些依賴包。

  1. yum install perl perl-DBI perl-DBD-MySQL perl-IO-Socket-SSL perl-Time-HiRes

類比異常關機的處理
1.JAVA程式不斷寫入Master

  1. import java.sql.Connection;
  2. import java.sql.DriverManager;
  3. import java.sql.PreparedStatement;
  4. import java.sql.SQLException;
  5. public class Test {
  6. public static void main(String[] args) throws ClassNotFoundException,
  7. SQLException {
  8. long start = System.currentTimeMillis();
  9. Class.forName("com.mysql.jdbc.Driver");
  10. Connection connection = DriverManager.getConnection(
  11. "jdbc:mysql://192.168.1.70:3306/xx", "xx", "xx");
  12. connection.setAutoCommit(true);
  13. PreparedStatement cmd = connection
  14. .prepareStatement("insert into test(name) values(?)");
  15. for (int i = 0; i < 100000000; i++) {
  16. cmd.setString(1, "test");
  17. cmd.executeUpdate();
  18. }
  19. connection.commit();
  20. cmd.close();
  21. connection.close();
  22. long end = System.currentTimeMillis();
  23. System.out.println(end - start);
  24. }
  25. }

2.關閉Slave虛擬機器
在JAVA程式運行當中,直接強制關閉Slave虛擬機器。然後重新啟動Slave

啟動之後,發現複製出現異常。(Show slave status\G)

這個表除了自增的ID,就是name欄位,預設都是test
現在在slave上修改name欄位為‘mysql’
update test set name='mysql';

3.使用pt-slave-restart命令修複錯誤。

  1. [root@mysql2 ~]# pt-slave-restart --user=root --password=xxxxxxx --error-numbers=1062
  2. 2014-06-16T01:17:47 p=...,u=root mysql2-relay-bin.000003 312116 1062
  3. 2014-06-16T01:17:47 p=...,u=root mysql2-relay-bin.000003 312373 1062
  4. 2014-06-16T01:17:47 p=...,u=root mysql2-relay-bin.000003 312630 1062
  5. 2014-06-16T01:17:47 p=...,u=root mysql2-relay-bin.000003 312887 1062
  6. 2014-06-16T01:17:48 p=...,u=root mysql2-relay-bin.000003 313144 1062
  7. 2014-06-16T01:17:48 p=...,u=root mysql2-relay-bin.000003 313401 1062
  8. 2014-06-16T01:17:48 p=...,u=root mysql2-relay-bin.000003 313658 1062
  9. 2014-06-16T01:17:48 p=...,u=root mysql2-relay-bin.000003 313915 1062
  10. 2014-06-16T01:17:48 p=...,u=root mysql2-relay-bin.000003 314172 1062
  11. 2014-06-16T01:17:48 p=...,u=root mysql2-relay-bin.000003 314429 1062
  12. 2014-06-16T01:17:48 p=...,u=root mysql2-relay-bin.000003 314686 1062
  13. 2014-06-16T01:17:48 p=...,u=root mysql2-relay-bin.000003 314943 1062
  14. 2014-06-16T01:17:48 p=...,u=root mysql2-relay-bin.000003 315200 1594
  15. Error 1594 is not in --error-numbers.

發現還有1594的錯誤


重新串連Master
參考:



最後查看複製的情況,已經正常運行了。

我們在Master輸入的name都是test,而在Slave故障之後,將name都改為了mysql。
一般來說,處理主鍵重複無外乎兩種方式(我能想到的)
1.忽略Master發來的重複的binlog事件
2.使用Master的binlog事件更新slave資料
如果是第一種方式,slave的name應該都是mysql
如果是第二種方式,應該前部分是mysql,後一部分是test

測試結果如下,可以初步表明使用的是第二種方式。
下面302條name為'test'的記錄都是異常關機時,已經執行卻沒有將pos寫入檔案的那部分資料。
pt-slave-restart將這部分資料的binlog重新執行,所以它們的name為'test’。

--------------------------------------分割線 --------------------------------------

Ubuntu 14.04下安裝MySQL

《MySQL權威指南(原書第2版)》清晰中文掃描版 PDF

Ubuntu 14.04 LTS 安裝 LNMP Nginx\PHP5 (PHP-FPM)\MySQL

Ubuntu 14.04下搭建MySQL主從伺服器

Ubuntu 12.04 LTS 構建高可用分布式 MySQL 叢集

Ubuntu 12.04下原始碼安裝MySQL5.6以及Python-MySQLdb

--------------------------------------分割線 --------------------------------------

本文永久更新連結地址:

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.