0

0

如何在Docker中部署MySQL主从复制的详细教程?

絕刀狂花

絕刀狂花

发布时间:2025-06-28 20:45:02

|

418人浏览过

|

来源于php中文网

原创

docker中部署mysql主从复制的步骤如下:1. 创建docker网络,确保主从容器通信;2. 使用docker run命令创建主数据库容器并配置复制用户权限;3. 创建从数据库容器并连接同一网络;4. 在从数据库中配置主库信息并启动复制;5. 验证主从复制是否生效;6. 可使用docker compose简化多容器部署;7. 通过半同步复制、gtid、监控等手段保障数据一致性;8. 故障转移时停止从库复制、提升为新主库,并更新应用和从库配置。

如何在Docker中部署MySQL主从复制的详细教程?

简而言之,在Docker中部署MySQL主从复制涉及创建多个容器,配置网络,并设置MySQL服务器的角色。这需要一定的网络知识和对MySQL复制机制的理解。

如何在Docker中部署MySQL主从复制的详细教程?

解决方案:

如何在Docker中部署MySQL主从复制的详细教程?
  1. 创建Docker网络: 首先,创建一个Docker网络,以便主数据库和从数据库容器可以相互通信。

    docker network create mysql-net
  2. 创建主数据库容器: 使用docker run命令创建一个主数据库容器。需要指定MySQL版本、端口映射、数据卷挂载以及root用户密码等。

    如何在Docker中部署MySQL主从复制的详细教程?
    docker run --name mysql-master -d \
      -e MYSQL_ROOT_PASSWORD=your_root_password \
      -v mysql_master_data:/var/lib/mysql \
      -p 3306:3306 \
      --net mysql-net \
      mysql:8.0
    • --name mysql-master:指定容器名称。
    • -d:后台运行容器。
    • -e MYSQL_ROOT_PASSWORD=your_root_password:设置root用户密码。
    • -v mysql_master_data:/var/lib/mysql:挂载数据卷,持久化数据。
    • -p 3306:3306:映射端口,允许外部访问。
    • --net mysql-net:将容器连接到之前创建的网络。
    • mysql:8.0:使用MySQL 8.0镜像。
  3. 配置主数据库: 进入主数据库容器,执行以下命令配置复制用户和权限。

    docker exec -it mysql-master bash
    mysql -uroot -p'your_root_password'

    在MySQL客户端中执行:

    CREATE USER 'repl'@'%' IDENTIFIED BY 'your_replication_password';
    GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%';
    FLUSH PRIVILEGES;
    SHOW MASTER STATUS;

    记录FilePosition的值,稍后将在从数据库配置中使用。

  4. 创建从数据库容器: 创建一个从数据库容器,与主数据库容器类似,但需要指定不同的名称和端口。

    docker run --name mysql-slave -d \
      -e MYSQL_ROOT_PASSWORD=your_root_password \
      -v mysql_slave_data:/var/lib/mysql \
      -p 3307:3306 \
      --net mysql-net \
      mysql:8.0
  5. 配置从数据库: 进入从数据库容器,执行以下命令配置复制。

    docker exec -it mysql-slave bash
    mysql -uroot -p'your_root_password'

    在MySQL客户端中执行:

    CHANGE MASTER TO
      MASTER_HOST='mysql-master',
      MASTER_USER='repl',
      MASTER_PASSWORD='your_replication_password',
      MASTER_LOG_FILE='the_file_value_from_master',
      MASTER_LOG_POS=the_position_value_from_master;
    
    START SLAVE;
    SHOW SLAVE STATUS\G

    检查Slave_IO_RunningSlave_SQL_Running是否都为Yes

  6. 验证复制: 在主数据库中创建一个新的数据库或表,然后在从数据库中验证是否已成功复制。

    -- 在主数据库中
    CREATE DATABASE test_replication;
    USE test_replication;
    CREATE TABLE test_table (id INT PRIMARY KEY);
    INSERT INTO test_table VALUES (1);
    
    -- 在从数据库中
    USE test_replication;
    SELECT * FROM test_table;

如何在Docker Compose中简化MySQL主从复制的部署?

Docker Compose可以通过一个docker-compose.yml文件来定义和管理多个Docker容器。使用Docker Compose可以简化MySQL主从复制的部署,避免手动运行多个docker run命令。

Replit Agent
Replit Agent

Replit最新推出的AI编程工具,可以帮助用户从零开始自动构建应用程序。

下载

创建一个docker-compose.yml文件,内容如下:

version: "3.8"
services:
  mysql-master:
    image: mysql:8.0
    container_name: mysql-master
    environment:
      MYSQL_ROOT_PASSWORD: your_root_password
    volumes:
      - mysql_master_data:/var/lib/mysql
    ports:
      - "3306:3306"
    networks:
      - mysql-net

  mysql-slave:
    image: mysql:8.0
    container_name: mysql-slave
    environment:
      MYSQL_ROOT_PASSWORD: your_root_password
    volumes:
      - mysql_slave_data:/var/lib/mysql
    ports:
      - "3307:3306"
    networks:
      - mysql-net
    depends_on:
      - mysql-master

networks:
  mysql-net:

volumes:
  mysql_master_data:
  mysql_slave_data:

然后,运行以下命令启动容器:

docker-compose up -d

后续的配置步骤与手动运行docker run命令类似,需要进入容器配置MySQL复制。

如何处理MySQL主从复制中的数据一致性问题?

MySQL主从复制可能会遇到数据一致性问题,例如由于网络延迟、主数据库崩溃等原因导致从数据库未能及时同步数据。以下是一些处理数据一致性问题的方法:

  • 半同步复制: 启用半同步复制可以确保主数据库在提交事务之前至少有一个从数据库接收到该事务。这可以提高数据一致性,但会增加主数据库的延迟。
    • 安装半同步复制插件:在主从数据库上都安装。
    • 配置:在主数据库上启用半同步,设置等待从库数量。
  • GTID复制: 使用GTID(全局事务ID)复制可以简化故障转移和恢复过程,并提高数据一致性。GTID为每个事务分配一个唯一的ID,从数据库可以使用GTID来跟踪已复制的事务。
  • 监控和告警: 实施监控系统,定期检查主从复制状态,并在出现延迟或错误时发出告警。可以使用工具如Prometheus和Grafana进行监控。
  • 数据校验: 定期进行数据校验,比较主数据库和从数据库的数据是否一致。可以使用工具如pt-table-sync进行数据同步。
  • 优化网络: 确保主数据库和从数据库之间的网络连接稳定可靠,减少网络延迟。

如何进行MySQL主从复制的故障转移?

当主数据库发生故障时,需要进行故障转移,将从数据库提升为主数据库。以下是一个简单的故障转移流程:

  1. 停止从数据库复制: 在从数据库上执行STOP SLAVE;命令停止复制。

  2. 提升从数据库为主数据库: 在从数据库上执行以下命令:

    RESET MASTER;

    这将重置从数据库的复制状态,使其成为一个新的主数据库。

  3. 更新应用程序配置: 将应用程序的数据库连接配置指向新的主数据库。

  4. 配置其他从数据库: 如果有其他从数据库,需要将其配置为复制新的主数据库。使用CHANGE MASTER TO命令,指向新的主数据库。

  5. 监控新的主数据库: 确保新的主数据库运行正常,并继续监控复制状态。

在实际生产环境中,故障转移可能涉及更复杂的步骤,例如使用自动化工具进行故障检测和切换,以及使用负载均衡器来管理数据库连接。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

663

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

246

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

281

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

514

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

253

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

386

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

529

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

599

2023.08.14

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

43

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.8万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 798人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号