当前位置: 首页 > article >正文

我们来学mysql -- 从库重启,是否同步主库数据

从库重启后,通常不需要重新复制主库的全部数据,然后再开启复制。MySQL 的主从复制机制设计了优雅的恢复流程,可以在从库重启后继续从上次中断的位置继续复制,前提是相关的日志和状态信息完整。

以下是详细解释:

从库重启后的复制行为

  1. 记录复制进度

    • 在主从复制中,从库会记录主库的 binlog 文件名和位置(通过 relay_logmaster_info_repository 等机制)。这些信息存储在从库的 master.info 文件或系统表中(取决于配置)。
    • 当从库重启后,它会读取这些记录,知道上次复制到主库的哪个位置。
  2. 继续复制流程

    • 从库重启后,I/O 线程会根据记录的主库 binlog 位置,从主库获取后续的 binlog 事件。
    • SQL 线程会继续从 relay log 中读取并执行未完成的更新操作。

是否需要重新同步数据

  • 通常不需要重新同步:只要从库的 relay log 和相关的状态信息完整,从库可以从中断的位置继续复制。

  • 可能需要重新同步的场景

    • 如果 relay log 文件被意外删除或损坏。
    • 如果从库的复制进度记录丢失或损坏。
    • 如果主库的 binlog 文件被清理(主库的 expire_logs_days 参数导致旧日志被删除)。

确保复制正常恢复的操作

  1. 检查复制状态

    • 在从库重启后,执行 SHOW SLAVE STATUS\G,查看以下关键字段:

      • Slave_IO_RunningSlave_SQL_Running 应该都为 Yes
      • Seconds_Behind_Master 表示从库落后主库的时间,逐渐减少表示复制正常进行。
  2. 验证数据一致性

    • 使用工具(如 pt-table-checksum)检查主从数据一致性。
  3. 配置自动恢复

    • 确保 relay_log_recovery = ON,这样从库在重启后会尝试从主库的最新位置重新开始复制。

重新同步数据的步骤(如果需要)

如果从库的数据或日志损坏,可能需要重新同步数据:

  1. 停止从库复制

    STOP SLAVE;
    
  2. 删除旧的 relay log 文件

    RESET SLAVE;
    
  3. 从主库获取新的备份

    • 使用工具(如 mysqldump 或物理备份工具)获取主库的最新数据。
  4. 重新配置复制

    • 执行 CHANGE MASTER TO 指令,重新指定主库的 binlog 文件和位置。

总结

  • 通常不需要重新同步:从库会自动从中断的位置继续复制。
  • 在特殊情况下(如日志损坏)可能需要重新同步:此时需手动干预,重新备份主库数据并配置复制。
http://www.lryc.cn/news/2395243.html

相关文章:

  • King3399(ubuntu文件系统)iic(i2c)功能测试
  • 德思特新闻 | 德思特与es:saar正式建立合作伙伴关系
  • 基于原生JavaScript前端和 Flask 后端的Todo 应用
  • 一些Dify聊天系统组件流程图架构图
  • jq处理日志数据
  • Matlab程序设计基础
  • MIT 6.S081 2020 Lab6 Copy-on-Write Fork for xv6 个人全流程
  • 第304个Vulnhub靶场演练攻略:digital world.local:FALL
  • Unity 模拟高度尺系统开发详解——实现拖动、范围限制、碰撞吸附与本地坐标轴选择
  • 万字详解RTR RTSP SDP RTCP
  • 云服务器如何自动更新系统并保持安全?
  • 训练中常见的运动强度分类
  • java 递归地复制文件夹及其所有子文件夹和文件
  • [paddle]paddle2onnx无法转换Paddle3.0.0的json格式paddle inference模型
  • React项目在ios和安卓端要做一个渐变色背景,用css不支持,可使用react-native-linear-gradient
  • 【数据分析】特征工程-特征选择
  • 第4节 Node.js NPM 使用介绍
  • RK3399 Android7.1增加应用安装白名单机制
  • uni-app 安卓消失的字符去哪里了?maxLength失效了!
  • #AI短视频制作完整教程
  • 嵌入式STM32学习——串口USART 2.0(printf重定义及串口发送)
  • 【大模型】情绪对话模型项目研发
  • Git 教程 | 如何将指定文件夹回滚到上一次或某次提交状态(命令详解)
  • 【PCI】PCI入门介绍(包含部分PCIe讲解)
  • Cloudera Manager 学习笔记
  • Deepin 23.10安装Docker
  • 使用PowerBI个人网关定时刷新数据
  • 数字人引领政务新风尚:智能设备助力政务服务
  • 深入剖析Java类加载机制:双亲委派模型的突破与实战应用
  • Kotlin JVM 注解详解