迁移 Docker 中的 MySQL 容器

迁移 Docker 中的 MySQL 容器

在这篇文章中,我们将介绍如何将在 Docker 中运行的 MySQL 容器从一台机器(我们称之为A机器)迁移到另一台机器(我们称之为B机器)。这个过程主要包括五个步骤:提交容器为镜像,保存镜像为 tar 包,将 tar 包传输到新机器,迁移数据,再在新机器上启动服务。

第一步:提交容器为镜像

首先,我们需要将正在运行的 MySQL 容器提交为一个 Docker 镜像。提交操作会捕获容器的当前状态,并将其保存为一个新的镜像。在 A 机器上,我们可以使用 docker commit 命令来完成这个操作:

bash 复制代码
docker commit mysql mysql-migration:latest

这个命令将 mysql 容器的当前状态保存为一个名为 mysql-migration 的新镜像。

第二步:保存镜像为 tar 包

接下来,我们需要将新创建的镜像保存为一个 tar 包,以便我们可以将它传输到 B 机器。我们可以使用 docker save 命令来完成这个操作:

bash 复制代码
docker save mysql-migration:latest > mysql-migration.tar

这个命令将 mysql-migration 镜像保存为 mysql-migration.tar 文件。

第三步:将 tar 包传输到 B 机器

现在,我们需要将 tar 包传输到 B 机器。我们可以使用 scp(安全复制)命令来完成这个操作:

bash 复制代码
scp mysql-migration.tar user@B机器的IP地址:/path/to/destination

请将 user@B机器的IP地址:/path/to/destination 替换为 B 机器的实际用户、IP地址和目标路径。

第四步:迁移数据到 B 机器

在 B 机器上,我们首先需要加载我们刚刚传输过来的 Docker 镜像。我们可以使用 docker load 命令来完成这个操作:

bash 复制代码
docker load < mysql-migration.tar

接下来,我们需要将数据目录(在这个例子中,位于 /opt/module/mysql/mysql8-standalone/data)迁移到 B 机器。这个过程将取决于你的网络设施和数据大小。一种常见的方法是使用 rsync

bash 复制代码
rsync -avz -e ssh user@A机器的IP地址:/opt/module/mysql/mysql8-standalone/data /opt/module/mysql/mysql8-standalone/data

第五步:在 B 机器上启动服务

最后,我们在 B 机器上使用 Docker Compose 启动新的 MySQL 服务。首先,我们需要创建一个新的 docker-compose.yml 文件,它应该看起来像这样:

yaml 复制代码
version: '3'
services:
  mysql:
    image: mysql-migration:latest
    container_name: mysql
    privileged: true
    restart: always
    ports:
      - "8306:3306"
    volumes:
      - /opt/module/mysql/mysql8-standalone/data:/var/lib/mysql
      - /opt/module/mysql/mysql8-standalone/conf/my.cnf:/etc/mysql/conf.d/my.cnf
      - /opt/module/mysql/mysql8-standalone/logs:/logs

然后,我们可以使用 docker-compose up 命令来启动服务:

bash 复制代码
docker-compose up -d

至此,我们已经成功地将 MySQL 服务从 A 机器迁移到了 B 机器。这个过程需要对 Docker 有一定的理解,但是一旦你掌握了这些步骤,你将能够灵活地在不同的机器之间迁移 Docker 容器。

相关推荐
copyer_xyf13 分钟前
FastAPI 如何连接 MySQL
后端·python
IT_陈寒27 分钟前
Vite打包时踩的坑:静态资源为啥突然404了?
前端·人工智能·后端
葫芦和十三1 小时前
图解 MongoDB 25|分片架构三件套:mongos、config server 和 shard
后端·mongodb·agent
葫芦和十三8 小时前
图解 MongoDB 26|片键设计:决定集群命运的一个决定
后端·mongodb·agent
Avan_菜菜9 小时前
使用 Docker + rclone 自建 WebDAV
后端·agent·claude
阳光是sunny10 小时前
别再被 worktree 绕晕了!AI 编程时代你必须掌握的 Git 隔离神器
前端·人工智能·后端
万少11 小时前
万少的博客 - 技术分享与解决方案
前端·javascript·后端
咖啡八杯12 小时前
GoF设计模式——备忘录模式
java·后端·spring·设计模式
苍何12 小时前
腾讯再放大招,企微 Agent 大圆开启内测
后端
ethantan12 小时前
一篇讲解AI Agent 组成:像人一样思考的智能体
人工智能·后端·程序员