docker 迁移mysql容器

迁移整个 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;
相关推荐
橘颂TA1 小时前
【MySQL】内置函数
数据库·mysql
橘颂TA2 小时前
【MySQL】使用C/C++来连接 MySQL
数据库·mysql
Y001112362 小时前
Day2-MySQL-SQL-1
sql·mysql·oracle
AnalogElectronic2 小时前
云原生学习day1ubuntu安装docker,基础镜像打包
学习·docker·云原生
艾莉丝努力练剑3 小时前
【Linux进程间通信:共享内存】为什么共享内存的 key 值由用户设置
java·linux·运维·服务器·开发语言·数据库·mysql
天若有情6733 小时前
【实战】从零开发企业级 B 端风格字符串值管理系统(Python+MySQL)
开发语言·python·mysql·企业级应用·b端应用
KubeSphere 云原生3 小时前
云原生周刊:Docker 是什么?容器革命的起点
docker·云原生·容器
fengyehongWorld3 小时前
docker 常用命令
运维·docker·容器
m0_635647484 小时前
Qt开发与MySQL数据库教程(二)——MySQL常用命令以及示例
java·开发语言·数据库·mysql