我们来学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 文件和位置。

总结

  • 通常不需要重新同步:从库会自动从中断的位置继续复制。
  • 在特殊情况下(如日志损坏)可能需要重新同步:此时需手动干预,重新备份主库数据并配置复制。
<think>我们将在CentOS 9上使用Docker部署MySQL 5.7主从复制架构。主要步骤包括: 1. 创建自定义网络 2. 部署主库(master)容器,配置数据目录挂载和root密码 3. 在主库中创建复制用户并授权 4. 部署从(slave)容器,配置数据目录挂载和root密码 5. 配置主库和从的my.cnf文件(包括server-id等) 6. 在从上配置主库连接信息并启动复制 注意:我们将使用数据卷挂载来持久化数据和配置,并设置root密码。 步骤详细说明: 1. 创建自定义网络(如果尚未创建): ```bash docker network create mysql-net ``` 2. 部署主库容器: ```bash docker run -d --name mysql-master \ --net mysql-net \ -p 3306:3306 \ -v /data/mysql_master/data:/var/lib/mysql \ -v /data/mysql_master/conf:/etc/mysql/conf.d \ -e MYSQL_ROOT_PASSWORD=masterpassword \ mysql:5.7 ``` 3. 在主库中配置复制用户: 进入主库容器: ```bash docker exec -it mysql-master mysql -uroot -pmasterpassword ``` 在MySQL命令行中执行: ```sql CREATE USER 'repl'@'%' IDENTIFIED BY 'replpassword'; GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%'; FLUSH PRIVILEGES; ``` 4. 配置主库的my.cnf文件(在宿主机路径:/data/mysql_master/conf/my.cnf): ```ini [mysqld] server-id=1 log-bin=mysql-bin binlog_format=ROW ``` 重启主库容器使配置生效: ```bash docker restart mysql-master ``` 5. 部署从容器: ```bash docker run -d --name mysql-slave \ --net mysql-net \ -p 3307:3306 \ -v /data/mysql_slave/data:/var/lib/mysql \ -v /data/mysql_slave/conf:/etc/mysql/conf.d \ -e MYSQL_ROOT_PASSWORD=slavepassword \ mysql:5.7 ``` 6. 配置从的my.cnf文件(在宿主机路径:/data/mysql_slave/conf/my.cnf): ```ini [mysqld] server-id=2 relay-log=mysql-relay-bin read_only=1 ``` 重启容器: ```bash docker restart mysql-slave ``` 7. 获取主库的binlog位置(在主库容器中执行): ```bash docker exec -it mysql-master mysql -uroot -pmasterpassword -e "SHOW MASTER STATUS;" ``` 记录下返回的File和Position值(例如:mysql-bin.000001,154)。 8. 在从上配置主库连接信息: 进入从容器: ```bash docker exec -it mysql-slave mysql -uroot -pslavepassword ``` 在MySQL命令行中执行(替换MASTER_HOST为mysql-master,因为我们在同一个自定义网络,可以使用容器名): ```sql CHANGE MASTER TO MASTER_HOST='mysql-master', MASTER_USER='repl', MASTER_PASSWORD='replpassword', MASTER_LOG_FILE='mysql-bin.000001', -- 替换为实际文件 MASTER_LOG_POS=154; -- 替换为实际位置 START SLAVE; ``` 9. 检查从复制状态: ```sql SHOW SLAVE STATUS \G; ``` 确保Slave_IO_Running和Slave_SQL_Running都是Yes。 注意:如果出现错误,可以查看从的错误日志(在容器内/var/log/mysql/error.log,或者宿主机挂载的日志目录,但注意我们上面没有挂载日志目录,如果需要可以添加-v挂载日志目录)。 另外,为了避免root用户登录问题(如ERROR 1045),我们可以在主库和从的配置文件中加入以下配置(在[mysqld]部分): ```ini default_authentication_plugin=mysql_native_password ``` 然后重启容器。 同时,确保挂载目录的权限,Docker容器内的mysql用户(uid 999)需要有读写权限。可以在宿主机上设置: ```bash sudo chown -R 999:999 /data/mysql_master sudo chown -R 999:999 /data/mysql_slave ``` 如果遇到权限问题,可以在启动容器时使用--privileged参数(如引用[1]所示)或者设置正确的目录权限。 最后,由于我们使用了自定义网络(mysql-net),主从容器之间可以通过容器名称互相访问。 以上步骤即可完成MySQL 5.7主从复制的Docker部署。 相关问题: 1. 如何避免 Docker 中 MySQL 的权限问题? 2. MySQL 主从复制中断后如何自动恢复? 3. 如何监控 Docker 容器的 MySQL 错误日志? 4. MySQL 8.0 与 5.7 在 Docker 中的身份验证有何区别?</think>### 在 CentOS 9 上部署 MySQL 5.7 主从复制架构 #### 步骤 1: 创建 Docker 网络和数据目录 ```bash # 创建共享网络 docker network create mysql-net # 创建主从数据目录 sudo mkdir -p /data/mysql_{master,slave}/{conf,data,log} sudo chown -R 999:999 /data/mysql_* # 授予容器内MySQL用户权限 ``` #### 步骤 2: 部署主库 (Master) ```bash docker run -d --name mysql_master \ --net mysql-net \ -p 3306:3306 \ -v /data/mysql_master/conf:/etc/mysql/conf.d \ -v /data/mysql_master/data:/var/lib/mysql \ -v /data/mysql_master/log:/var/log/mysql \ -e MYSQL_ROOT_PASSWORD=masterpassword \ mysql:5.7 ``` #### 步骤 3: 配置主库 my.cnf 编辑 `/data/mysql_master/conf/my.cnf`: ```ini [mysqld] server-id=1 log-bin=mysql-bin binlog_format=ROW expire_logs_days=3 max_binlog_size=100M default_authentication_plugin=mysql_native_password # 解决认证问题[^1] ``` 重启主库:`docker restart mysql_master` #### 步骤 4: 在主库创建复制用户 ```bash docker exec -it mysql_master mysql -uroot -pmasterpassword ``` ```sql CREATE USER 'repl'@'%' IDENTIFIED BY 'replpassword'; GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%'; FLUSH PRIVILEGES; SHOW MASTER STATUS; -- 记录File和Position值 ``` #### 步骤 5: 部署从 (Slave) ```bash docker run -d --name mysql_slave \ --net mysql-net \ -p 3307:3306 \ -v /data/mysql_slave/conf:/etc/mysql/conf.d \ -v /data/mysql_slave/data:/var/lib/mysql \ -v /data/mysql_slave/log:/var/log/mysql \ -e MYSQL_ROOT_PASSWORD=slavepassword \ mysql:5.7 ``` #### 步骤 6: 配置从 my.cnf 编辑 `/data/mysql_slave/conf/my.cnf`: ```ini [mysqld] server-id=2 relay-log=mysql-relay-bin read_only=1 default_authentication_plugin=mysql_native_password ``` 重启:`docker restart mysql_slave` #### 步骤 7: 配置主从复制链路 ```bash docker exec -it mysql_slave mysql -uroot -pslavepassword ``` ```sql CHANGE MASTER TO MASTER_HOST='mysql_master', MASTER_USER='repl', MASTER_PASSWORD='replpassword', MASTER_LOG_FILE='mysql-bin.000001', -- 替换主库SHOW MASTER STATUS的值 MASTER_LOG_POS=154; -- 替换主库SHOW MASTER STATUS的值 START SLAVE; SHOW SLAVE STATUS \G; -- 验证Slave_IO_Running和Slave_SQL_Running状态 ``` #### 验证主从复制 在主库创建测试数据: ```sql CREATE DATABASE replication_test; USE replication_test; CREATE TABLE test(id INT PRIMARY KEY); INSERT INTO test VALUES(1); ``` 在从验证数据同步: ```sql SELECT * FROM replication_test.test; ``` ### 关键配置说明 1. **网络配置**:使用自定义网络 `mysql-net` 确保容器间通过名称通信 2. **认证插件**:`default_authentication_plugin=mysql_native_password` 解决 Docker 环境认证问题 3. **数据持久化**:通过 `-v` 挂载实现数据目录持久化 4. **复制用户**:专用复制账号避免使用 root 账号[^4] 5. **只读从**:`read_only=1` 确保从数据安全 ### 故障排查技巧 ```bash # 查看从日志 docker logs mysql_slave # 检查复制状态 docker exec mysql_slave mysql -uroot -pslavepassword -e "SHOW SLAVE STATUS \G" # 检查主库连接 docker exec mysql_slave mysql -urepl -preplpassword -h mysql_master ``` ### 主从复制架构图 ```mermaid graph LR A[客户端] --> B[主库 3306] B --> C[二进制日志] C --> D[从 3307] D --> E[中继日志] E --> F[数据应用] ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

UCoding

说话好听~~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值