首页 数据库 mysql教程 MySQL Slave异常关机的处理

MySQL Slave异常关机的处理

Jun 07, 2016 pm 04:50 PM

生产环境有一个MySQL的Master-Slave的复制。前一阵子机房网络升级,但是考虑到一般网络故障恢复之后,只需要start slave即可所以没

生产环境有一个MySQL的Master-Slave的复制。

前一阵子机房网络升级,但是考虑到一般网络故障恢复之后,只需要start slave即可

所以没有做任何的处理。

但是第二天上班的时候,在Slave数据库上输入命令,start slave 不能重新启动复制。

模拟环境如下

在Slave上启动复制,报错如下

复制过程出现主键重复了

最后,使用status查看,发现MySQL被重启过。

估计在割接过程中,莫名其妙的被人按了服务器的重启键吧。

但是MySQL复制针对这种情况,异常的脆弱,因为复制的信息都写在一个文件里,

考虑到性能的原因,这个写入并不是同步的。

也就是说在断电重启的瞬间,复制的情况并没有写入到文件中。

而再次启动之后,读取这个文件中记录的复制位置,肯定落后于实际执行的位置。

所以会发生主键重复的问题,因为这个记录实际已经执行过了。

解决这个问题有三种方式

1.设置sql_slave_skip_counter跳过Master发来的事件,直到正常的位置

启动之后,发现报错信息已经变了

他重复的主键已经从7940到了7946了,也就说通过一点一点的推进,是可以推进到正常的复制位置的。

但是工作量比较大,需要很有耐心和时间做这个事情。

2.设置slave_skip_errors

在my.cnf配置文件中设置slave_skip_errors=1062,跳过所有主键重复的错误。

但是这个参数设置之后,,需要重启服务。对于生产系统来说,没有实际意义。

3.设置slave_exec_mode

MySQL默认的slave执行方式是严格的。

类似主键重复的问题,会直接停止复制,等待人工介入。

slave_exec_mode是一个动态参数,如果设置为IDEMPOTENT可以自动忽略主键重复和没有找到记录的错误。

但是貌似只是在MySQL集群环境有效

异常断电和关机除了可能导致主键重复的错误之外,还可能导致中继日志损坏

针对这个问题,首先,找到master binlog执行的位置

位置

然后重新连接Master服务器,(需要先停止slave)

最后查看复制情况,已经正常。

这次的经验是,如果预计可能发生状况,比如这次网络割接,

可以先停止slave的服务器。因为我们的slave只是作为备份的一种方式,而不是用于读写分离。

或者干脆设置slave_skip_errors参数。

 

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

Ubuntu 14.04下安装MySQL

《MySQL权威指南(原书第2版)》清晰中文扫描版 PDF

Ubuntu 14.04 LTS 安装 LNMP NginxPHP5 (PHP-FPM)MySQL

Ubuntu 14.04下搭建MySQL主从服务器

Ubuntu 12.04 LTS 构建高可用分布式 MySQL 集群

Ubuntu 12.04下源代码安装MySQL5.6以及Python-MySQLdb

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

本文永久更新链接地址:

MySQL Slave异常关机的处理

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章标签

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

减少在Docker中使用MySQL内存的使用 减少在Docker中使用MySQL内存的使用 Mar 04, 2025 pm 03:52 PM

减少在Docker中使用MySQL内存的使用

如何使用Alter Table语句在MySQL中更改表? 如何使用Alter Table语句在MySQL中更改表? Mar 19, 2025 pm 03:51 PM

如何使用Alter Table语句在MySQL中更改表?

mysql无法打开共享库怎么解决 mysql无法打开共享库怎么解决 Mar 04, 2025 pm 04:01 PM

mysql无法打开共享库怎么解决

在 Linux 中运行 MySQl(有/没有带有 phpmyadmin 的 podman 容器) 在 Linux 中运行 MySQl(有/没有带有 phpmyadmin 的 podman 容器) Mar 04, 2025 pm 03:54 PM

在 Linux 中运行 MySQl(有/没有带有 phpmyadmin 的 podman 容器)

什么是 SQLite?全面概述 什么是 SQLite?全面概述 Mar 04, 2025 pm 03:55 PM

什么是 SQLite?全面概述

在MacOS上运行多个MySQL版本:逐步指南 在MacOS上运行多个MySQL版本:逐步指南 Mar 04, 2025 pm 03:49 PM

在MacOS上运行多个MySQL版本:逐步指南

哪些流行的MySQL GUI工具(例如MySQL Workbench,PhpMyAdmin)是什么? 哪些流行的MySQL GUI工具(例如MySQL Workbench,PhpMyAdmin)是什么? Mar 21, 2025 pm 06:28 PM

哪些流行的MySQL GUI工具(例如MySQL Workbench,PhpMyAdmin)是什么?

如何为MySQL连接配置SSL/TLS加密? 如何为MySQL连接配置SSL/TLS加密? Mar 18, 2025 pm 12:01 PM

如何为MySQL连接配置SSL/TLS加密?

See all articles