导读:本期聚焦于小伙伴创作的《MySQL主从同步故障中Slave_SQL_Running: No是什么原因怎么解决》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《MySQL主从同步故障中Slave_SQL_Running: No是什么原因怎么解决》有用,将其分享出去将是对创作者最好的鼓励。

MySQL主从同步是很多业务场景下的标准数据库部署方案,能够有效分担主库读压力,同时实现数据容灾备份。当出现Slave_SQL_Running: No的故障时,从库会停止执行主库同步过来的relay log中的SQL语句,数据同步进程中断,需要及时处理避免数据长期不一致。

MySQL主从同步故障中Slave_SQL_Running: No是什么原因怎么解决

故障常见原因

1. 从库执行SQL时出现错误

最常见的原因是主库同步过来的SQL语句在从库执行失败,比如从库不存在对应的表、字段不匹配、权限不足等。例如主库新增了一个字段,从库表结构没有同步更新,执行ALTER语句时就会报错。

2. 主从数据不一致导致冲突

如果从库提前存在和主库要插入的数据主键冲突的记录,或者要删除的记录在从库不存在,就会触发执行错误。比如在从库手动插入了一条id=10的记录,主库后续插入id=10的数据时,从库执行就会报主键重复错误。

3. 从库relay log损坏

从库的中继日志relay log如果出现损坏,SQL线程读取到不完整的日志内容时也会停止运行,状态变为No。

故障排查步骤

首先登录从库MySQL,执行以下命令查看同步状态:

SHOW SLAVE STATUS\G

重点关注以下几个字段:

  • Last_SQL_Error:会显示SQL线程停止的具体错误信息,是定位问题的核心依据
  • Last_SQL_Errno:对应的错误编号
  • Relay_Master_Log_File:当前SQL线程正在读取的主库binlog文件名
  • Exec_Master_Log_Pos:当前SQL线程执行到的主库binlog位置点

对应解决方法

方法1:跳过错误事务(适用于非核心数据不一致场景)

如果错误是偶发的、不影响业务数据一致性,可以跳过对应的错误事务。如果是单个错误,可以设置跳过错误数:

-- 停止从库同步线程
STOP SLAVE;
-- 设置跳过1个错误事务,根据具体错误数量调整
SET GLOBAL sql_slave_skip_counter = 1;
-- 重新启动从库同步
START SLAVE;

也可以修改从库配置文件,设置跳过指定的错误编号,比如跳过主键重复错误1062和记录不存在错误1032:

[mysqld]
slave-skip-errors=1062,1032

修改后重启MySQL服务,再启动从库同步即可。

方法2:重新同步不一致的表(适用于数据不一致场景)

如果是因为表数据不一致导致的错误,可以重新同步对应表的数据。步骤如下:

首先在主库锁定要同步的表,避免同步过程中数据变化:

-- 锁定表为只读
FLUSH TABLES WITH READ LOCK;
-- 查看当前主库binlog位置
SHOW MASTER STATUS;

然后导出该表的数据:

mysqldump -u root -p 数据库名 表名 > 表名.sql

将导出的SQL文件传到从库,在从库恢复数据:

mysql -u root -p 数据库名 < 表名.sql

之后回到主库解锁表:

UNLOCK TABLES;

最后在从库重新设置同步起点,启动同步:

STOP SLAVE;
-- 根据之前主库SHOW MASTER STATUS的结果设置
CHANGE MASTER TO MASTER_LOG_FILE='主库binlog文件名', MASTER_LOG_POS=主库位置点;
START SLAVE;

方法3:修复损坏的relay log

如果是relay log损坏,可以重置从库的relay log,重新从主库拉取:

STOP SLAVE;
-- 重置relay log
RESET SLAVE;
-- 重新设置主库同步信息,根据实际情况填写
CHANGE MASTER TO MASTER_HOST='主库IP', MASTER_USER='同步账号', MASTER_PASSWORD='同步密码', MASTER_LOG_FILE='主库当前binlog文件', MASTER_LOG_POS=主库当前位置点;
START SLAVE;

预防措施

为了避免Slave_SQL_Running: No故障反复出现,日常运维中可以做好以下几点:

  • 主从库的MySQL版本尽量保持一致,避免版本差异导致的语法兼容问题
  • 禁止在从库手动执行写操作,避免数据不一致
  • 主库表结构变更时,先在从库验证可行性,再同步执行
  • 定期监控主从同步状态,发现延迟或异常及时处理

MySQL主从同步Slave_SQL_Running故障排查数据同步修改时间:2026-06-06 22:50:58

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。