mysql 异常关机_MySQL Slave异常关机的处理 (pt-slave-restart)

MySQL Slave异常关机的处理除了后面的三个方法。http://www.linuxidc.com/Linux/2014-07/104235.htm

还可以使用percona-toolkit的pt-slave-restart命令。

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

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

模拟异常关机的处理

1.Java程序不断写入Master

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.PreparedStatement;

import java.sql.SQLException;

public classTest{

publicstatic void main(String[]args)throws ClassNotFoundException,

SQLException{

long start=System.currentTimeMillis();

Class.forName("com.mysql.jdbc.Driver");

Connection connection=DriverManager.getConnection(

"jdbc:mysql://192.168.1.70:3306/xx", "xx", "xx");

connection.setAutoCommit(true);

PreparedStatement cmd=connection

.prepareStatement("insert into test(name) values(?)");

for (inti=0;i<100000000;i++) {

cmd.setString(1, "test");

cmd.executeUpdate();

}

connection.commit();

cmd.close();

connection.close();

longend =System.currentTimeMillis();

System.out.println(end -start);

}

}

2.关闭Slave虚拟机

在JAVA程序运行当中,直接强制关闭Slave虚拟机。然后重新启动Slave

bcfbd0e52cb95d6409553b15281f2540.png

启动之后,发现复制出现异常。(Show slave status\G)

e40ab4f575cc5ba212082cd3d176740d.png

这个表除了自增的ID,就是name字段,默认都是test

现在在slave上修改name字段为‘mysql’

update test set name='mysql';

3.使用pt-slave-restart命令修复错误。

[root@mysql2 ~]# pt-slave-restart --user=root --password=xxxxxxx--error-numbers=1062

2014-06-16T01:17:47 p=...,u=root mysql2-relay-bin.000003 312116 1062

2014-06-16T01:17:47 p=...,u=root mysql2-relay-bin.000003 312373 1062

2014-06-16T01:17:47 p=...,u=root mysql2-relay-bin.000003 312630 1062

2014-06-16T01:17:47 p=...,u=root mysql2-relay-bin.000003 312887 1062

2014-06-16T01:17:48 p=...,u=root mysql2-relay-bin.000003 313144 1062

2014-06-16T01:17:48 p=...,u=root mysql2-relay-bin.000003 313401 1062

2014-06-16T01:17:48 p=...,u=root mysql2-relay-bin.000003 313658 1062

2014-06-16T01:17:48 p=...,u=root mysql2-relay-bin.000003 313915 1062

2014-06-16T01:17:48 p=...,u=root mysql2-relay-bin.000003 314172 1062

2014-06-16T01:17:48 p=...,u=root mysql2-relay-bin.000003 314429 1062

2014-06-16T01:17:48 p=...,u=root mysql2-relay-bin.000003 314686 1062

2014-06-16T01:17:48 p=...,u=root mysql2-relay-bin.000003 314943 1062

2014-06-16T01:17:48 p=...,u=root mysql2-relay-bin.000003 315200 1594

Error 1594 is not in --error-numbers.

发现还有1594的错误

ad1bef98a134160cfd654b5ae8dc4c2d.png

重新连接Master

参考: http://www.linuxidc.com/Linux/2014-07/104235.htm

56b44688dadd40bbbfc83561e80dd9d8.png

最后查看复制的情况,已经正常运行了。

我们在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’。

713709af0afa9984f97c547dc04253e0.png

--------------------------------------分割线 --------------------------------------

Ubuntu 14.04 LTS 安装 LNMP Nginx\PHP5 (PHP-FPM)\MySQL http://www.linuxidc.com/Linux/2014-05/102351.htm

--------------------------------------分割线 --------------------------------------

0b1331709591d260c1c78e86d0c51c18.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值