>데이터 베이스 >MySQL 튜토리얼 >MySQL Slave异常关机的处理 (pt-slave-restart)

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

WBOY
WBOY원래의
2016-06-07 16:50:331047검색

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

MySQL Slave异常关机的处理除了后面的三个方法。
还可以使用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

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

    这个表除了自增的ID,就是name字段,默认都是test
    现在在slave上修改name字段为‘mysql’
    update test set;

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

    发现还有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

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

    本文永久更新链接地址:

    linux

    성명:
    본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.