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;
相关推荐
唐青枫1 天前
MySQL JSON 实战详解:从存储、查询、更新到 JSON_TABLE 与索引
sql·mysql
小满8781 天前
5.Mysql事务隔离级别与锁机制
mysql
元Y亨H2 天前
技术笔记:MySQL 字符集排序规则与大小写敏感性问题解决方案
mysql
这个DBA有点耶3 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构
掉头发的王富贵3 天前
【StarRocks】极限十分钟入门StarRocks
数据库·sql·mysql
SamDeepThinking3 天前
一条UPDATE语句在MySQL 8.0中到底加了几把锁?
后端·mysql·程序员
Patrick_Wilson4 天前
从「改个端口」到 502:Next.js on k8s 的容器端口、Service 映射与 env 覆盖
docker·kubernetes·next.js
Suroy4 天前
DockerView-Go:用 Go 写一个终端 Docker 监控工具,顺便做了个 Web 仪表盘
docker
云恒要逆袭4 天前
运行你的第一个Docker容器
后端·docker·容器
李白客5 天前
KES新版MySQL兼容能力再升级意味着什么?
mysql·国产数据库