迁移整个 Docker 镜像 + 数据(含容器配置)
适合需要完全复刻原容器(包括端口、挂载、自启配置)的场景,一步到位。
步骤 1:原服务器备份镜像 + 数据卷
1.1 导出 MySQL 镜像
# 导出镜像到本地文件(替换镜像名和路径)
docker save -o /tmp/mysql_5.7.30.tar mysql:5.7.30
1.2 备份数据卷(关键!MySQL 数据存在挂载目录,需单独备份)
# 打包原服务器的 MySQL 挂载目录(替换为你的挂载路径,比如 /work/docker/mysql)
tar -zcvf /tmp/mysql_data.tar.gz /work/docker/mysql
步骤 2:传输文件到新服务器
# 传输镜像文件
scp /tmp/mysql_5.7.30.tar root@新服务器IP:/tmp/
# 传输数据卷文件
scp /tmp/mysql_data.tar.gz root@新服务器IP:/tmp/
步骤 3:新服务器恢复
3.1 导入 MySQL 镜像
docker load -i /tmp/mysql_5.7.30.tar
3.2 恢复数据卷
# 创建和原服务器一致的挂载目录
mkdir -p /work/docker/mysql
# 解压数据卷备份(覆盖到挂载目录)
tar -zxvf /tmp/mysql_data.tar.gz -C /
3.3 启动容器(和原命令一致,含自启、端口等配置)
docker run -p 3306:3306 \
--name mysql7 \
--privileged=true \
--restart=always \
-v /work/docker/mysql/log:/var/log/mysql \
-v /work/docker/mysql/data:/var/lib/mysql \
-v /work/docker/mysql/conf:/etc/mysql/conf.d \
-e MYSQL_ROOT_PASSWORD=123456 \
-d mysql:5.7.30
步骤 4:验证
# 进入容器查看数据
docker exec -it mysql7 mysql -uroot -p
show databases;