如何恢复MySQL主从数据一致性

最近被告知,MySQL主从数据库的数据不一致,猜测备库在同步过程中出现了问题,于是,登上备库,使用 mysql> show slave status\G查看,果然,备库在insert语句中因违反主键约束,导致备库停止了同步。现在的问题很明确,就是如何恢复主从库数据的一致性。可选方案如下:一、查看Master最新的Position,将其...
如何恢复MySQL主从数据一致性
最近被告知,MySQL主从数据库的数据不一致,猜测备库在同步过程中出现了问题,于是,登上备库,使用 mysql> show slave status\G查看,果然,备库在insert语句中因违反主键约束,导致备库停止了同步。现在的问题很明确,就是如何恢复主从库数据的一致性。可选方案如下:一、查看Master最新的Position,将其作为Slave复制的起点。这种思路体现的是过去的不一致既往不咎,现在保持同步即可。看起来,这个思路和恢复主从库数据的一致性的初衷有所违背,但这种方法,简单,高效,在测试环境,对历史数据要求不高的场景中可使用。二、必须严格的恢复主从库数据的一致性。在这里,也有两种思路:1. 备份主库数据,并在从库上恢复,在历史数据一致性的基础上开启同步,但这种方法比较麻烦,必须在主库上执行锁表操作,阻止客户端对于表数据的更新操作,而且在数据量大的情况下,备份也是个耗时的工程。其实,这种方法在实际生产环境中也很少用。2. Skip掉相关错误其实,这个说活不是很严谨,准备的说,是跳过相关的事务。在我今天这种情况下,就是skip掉因违反主键约束而失败的insert语句。如何跳过相关事务一、停止slave服务二、SET GLOBAL SQL_SLAVE_SKIP_COUNTER = 1;三、开启slave服务。这里跳过的是一个事务。当然,也可以跳过多个事务,但要谨慎,毕竟,你并不知道跳过的是什么事务。建议:可反复执行上述步骤,仔细查看导致从库不能同步的语句。有的时候,阻止从库的事务太多,这种方法就显得略为低效。可分析主库日志的事务,来确定SQL_SLAVE_SKIP_COUNTER的合适值。具体步骤如下:1、在备库中执行show slave status\G,确认以下两个参数根据上述两个参数的值,在主库中查看当前阻碍从库复制的事务以及之后的事务。mysql> SHOW BINLOG EVENTS in 'mysql-bin.000217' from 673146776;这个是查看日志文件mysql-bin.000217中事务ID为673146776后的所有事务。当然,SHOW BINLOG EVENTS的用法还是相当灵活的,下述方式均可。mysql> SHOW BINLOG EVENTS in 'mysql-bin.000217' from 673146776\Gmysql> SHOW BINLOG EVENTS in 'mysql-bin.000217' from 673146776 limit 10;也可在主机环境下通过mysqlbinlog命令查看 代码如下:# mysqlbinlog mysql-bin.000217 --start-position=673146776如何查询语句的执行情况在从库跳过相关事务,重新启动Slave后,Slave_IO_Running,Slave_SQL_Running两项均显示“YES”,但Seconds_Behind_Master并没有马上下降,反而缓慢上升。这时候,通过show processlist语句查看线程的执行情况,发现第一条语句执行时间太长,“State”列显示“Sending data”。关于“Sending data”的含义,官方说明如下:可见,该语句涉及了大量的磁盘读。为了进一步分析该语句的耗时分布,可设置profiling变量。步骤如下:一、在查询开始之前,设置set profiling=on;二、在语句执行完毕后,通过show profiles查看语句的Query_ID。三、通过show profile for queryQuery_ID 查看语句的具体执行情况。最后也发现,该语句在Sending data阶段耗时过久。总结:1. 在执行stop slave的时候,stop slave命令被hang住了,在网上查询了相关资料,可能与Slave中有长SQL或Locked的SQL执行有关,在这里,除show processlist外,最好不要执行show slave status以及slave stop等slave相关命令。那么如何解决该问题呢?等待锁定SlaveSQL的线程结束,或者重启数据库。我选择了后者。2. 在重启备库的过程中,还有段小插曲,在执行start slave命令的时候,报如下错误:ERROR 1872 (HY000): Slave failed to initialize relay log info structure from the repository。网上很多资料都是推荐重新配置主从集群,这样又回到了开头的方案选择部分了。奇怪的时,我关闭了从库,重新启动,又好了。而两次启动命令唯一的差别就是前一次启动使用的是mysqld,后一次启动使用的是mysqld_safe,而且多带了一个--user参数。2023-07-27
mengvlog 阅读 7 次 更新于 2025-07-20 11:13:17 我来答关注问题0
  •  阿暄生活 mysql主从复制数据不一致怎么办

    修复方案若数据严重不一致,可重新初始化从库,主库用mysqldump备份数据并加--single-transaction --master-data=2参数,从库导入备份并重新配置复制。对于局部不一致,使用pt-table-sync工具直接修复差异数据,需先备份。临时应急时可跳过错误事件,但可能导致数据永久不一致,仅用于非核心业务。预防措施配置...

  • 可选方案如下:一、查看Master最新的Position,将其作为Slave复制的起点。这种思路体现的是过去的不一致既往不咎,现在保持同步即可。看起来,这个思路和恢复主从库数据的一致性的初衷有所违背,但这种方法,简单,高效,在测试环境,对历史数据要求不高的场景中可使用。二、必须严格的恢复主从库数据的一致性...

  • 如果主库出现故障,你需要停止主库服务,将数据文件夹复制到主库,并重新启动主库。然后,在从库中重新设置master参数,并启动复制功能。一旦复制过程完成,从库将恢复与主库的数据一致性。需要注意的是,如果主库数据文件已经损坏,你可能需要从备份中恢复数据。在此情况下,建议定期进行数据库备份,并确...

  • 步骤一:检查数据完整性 首先,检查MySQL的master和slave的数据库完整性。首先,在MySQL上运行‘show master status’ 命令,查看状态,并确保数据完整性。此外,你还可以在MySQL上运行‘md5sum /var/lib/mysql/*’ 命令来比较master和slave上的数据文件,以确认数据完整性。步骤二:停止MySQL服务 停止MySQL...

  •  文暄生活科普 MySQL 主从复制的实现与数据不一致的解决方案

    MySQL 5.7 支持多种主从复制方法,其中最常用的是异步复制,其中主服务器(源)与从服务器(副本)之间进行数据同步。单向异步复制通过复制主服务器的二进制日志(binary log)事件并保持日志文件和位置同步来实现。从服务器主要通过主服务器的binlog文件获取数据来源,同时也能通过快照文件提前恢复数据。My...

檬味博客在线解答立即免费咨询

mySQL相关话题

Copyright © 2023 WWW.MENGVLOG.COM - 檬味博客
返回顶部