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;
相关推荐
imuliuliang6 分钟前
Java MySQL 连接
java·mysql·adb
羊小蜜.9 分钟前
Mysql 06: 表与字段别名全解——让 SQL 更简洁、可读性拉满
数据库·sql·mysql
WangJunXiang613 分钟前
MySQL 高可用
数据库·mysql
炸炸鱼.19 分钟前
MySQL 故障排查与生产环境优化(精简实用版)
数据库·mysql·adb
攒了一袋星辰38 分钟前
SequenceGenerator废弃序列号异步补偿机制技术实现方案
java·开发语言·数据库·mysql
熬夜的咕噜猫44 分钟前
MySQL 故障排查与优化
大数据·运维·服务器·mysql
刘晨鑫11 小时前
MySQL故障排查与生产环境优化
数据库·mysql·adb
PD我是你的真爱粉1 小时前
MySQL 锁机制:从理论分类到死锁实战
数据库·mysql·adb
正经教主1 小时前
安全养虾:[windows]Docker部署OpenClaw详细过程记录
安全·docker·容器
Benszen1 小时前
SQL 基础及 MySQL DBA 运维实战 - 6:Mycat代理技术
sql·mysql·dba