docker镜像与容器的迁移

docker容器迁移有两组命令,分别是

  • save & load :操作的是images, 所以要先把容器commit成镜像
  • export & import:直接操作容器

我们先主要看看他们的区别:

一 把容器打包为镜像再迁移到其他服务器

如把mysql这个容器(mysql是容器名)打包成镜像导出,再从其他机子上导入

把mysql容器打包为镜像

shell 复制代码
docker commit --author myt --message "create the mysql:5.7 by myt" mysql mysql:5.71
  • author 指明打包作者
  • message:指明打包描述信息
  • mysql:被打包的容器
  • mysql:5.71:打包后的镜像名称

执行上边的命令后,使用docker images可以查看新打包的镜像

导出刚打包的镜像

shell 复制代码
docker save -o mysql mysql:5.71

其中 第一个mysql是导出的文件名,可自定义。后面的mysql:5.71就是我们之前制作的新镜像。

导入镜像

把导出的mysql镜像文件,传到第二台linux机器随便一个目录, 执行下边命令导入到docker里,镜像就导入完成了

shell 复制代码
docker load -i mysql

docker images命令查看镜像列表,会发现mysql:5.71镜像已经导入进来了。

使用新导入的镜像启动容器

重新run一下,docker里的mysql服务就起来了,并且是带着第一台机器里的数据的

shell 复制代码
docker run -p 3306:3306 --name=mysql --privileged=true -v /mysql/data:/var/lib/mysql -v /mysql/log:/var/log/mysql -v /mysql/conf:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=123456  -d mysql:5.71

一 docker镜像迁移

通过将Docker镜像导出为文件,然后在目标环境中导入该文件,可以实现镜像的迁移,这里以mysql镜像迁移为例

执行docker images查看镜像列表

在源环境中运行以下命令,将镜像导出为文件

shell 复制代码
# 语法
docker save -o image.tar image_name
# 导出mysql镜像
docker save -o mysql.tar mysql

将导出的镜像文件传输到目标环境,并在目标环境中运行以下命令,将镜像导入

shell 复制代码
# 语法
docker load -i image.tar
# 导入mysql镜像
docker load -i mysql.tar

二 docker容器迁移

容器迁移包括容器的停止、导出、传输和导入,还是以mysql容器为例

  • 查看启动着的容器
shell 复制代码
docker ps
  • 停止容器
shell 复制代码
docker stop a818dc216f5c

在源环境中运行以下命令,将容器导出为文件

shell 复制代码
# 语法
docker export -o container.tar container_name
# 导出mysql容器
docker export -o mysql.tar mysql

在源环境机器执行一下命令

powershell 复制代码
docker ps --no-trunc

下边这个结果要记下来,在目标机器启动容器时用得到

将导出的容器文件传输到目标环境,然后在目标环境中运行以下命令,将容器导入

shell 复制代码
# 语法
docker import container.tar [new-image-name]
# 导入mysql容器
docker import mysql.tar mysql:5.7

在目标环境中启动导入的容器

shell 复制代码
# 语法
docker run container_name
# 运行mysql容器 注意,最后的"docker-entrypoint.sh mysqld" 要根据前边源机器执行docker ps --no-trunc的结果来变化
docker run -p 3306:3306 --name=mysql --privileged=true -v /mysql/data:/var/lib/mysql -v /mysql/log:/var/log/mysql -v /mysql/conf:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=123456  -d mysql:5.7 docker-entrypoint.sh mysqld
相关推荐
拾贰_C6 分钟前
【Linux | Windows | Terminal Command】 Linux---grep | Windows--- findstr
linux·运维·服务器
bloglin9999911 分钟前
启动容器报错ls: cannot access ‘/docker-entrypoint-initdb.d/‘: Operation not permitted
docker·容器·eureka
songjxin1 小时前
离线部署kubernetes v1.34.3
云原生·容器·kubernetes
虹科网络安全1 小时前
艾体宝洞察 | 利用“隐形字符”的钓鱼邮件:传统防御为何失效,AI安全意识培训如何补上最后一道防线
运维·网络·安全
石像鬼₧魂石1 小时前
Kali Linux 网络端口深度扫描
linux·运维·网络
alengan1 小时前
linux上面写python3日志服务器
linux·运维·服务器
yBmZlQzJ2 小时前
免费内网穿透-端口转发配置介绍
运维·经验分享·docker·容器·1024程序员节
JH30732 小时前
docker 新手入门:10分钟搞定基础使用
运维·docker·容器
小卒过河01043 小时前
使用apache nifi 从数据库文件表路径拉取远程文件至远程服务器目的地址
运维·服务器·数据库