Linux 环境下Docker将镜像打包导出到本地,上传至内网服务器(八)

冉升1周前行业资讯37

背景

docker将镜像导出到本地,上传至内网服务器上


背景:在企业中往往出现了内网不能和外网相通,不能使用docker pull命令来拉取镜像,这个时候我们就可以考虑在有所需镜像的服务器上导出镜像,再将其上传到内网服务器上。

有两种方法,一种是通过容器,一种是通过镜像,其实本质是一样的,容器的实质就是镜像

本文主要讲述的是第二种通过镜像的方式进行导出和上传

docker save用于导出镜像到文件,包含镜像元数据和历史信息;(个人推荐这种
docker export用于将当前容器状态导出至文件,类似快照,所以不包含元数据及历史信息,体积更小,此外从容器快照导入时也可以重新指定标签和元数据信息;

1. docker容器打包成镜像和压缩

(1)首先查看镜像所在的容器,获取到容器id

docker ps -a

28.png

(2)将容器保存成镜像

sudo docker commit -a 'yjw' e007d8b7e1b7 my_projectv2:v2

sudo:以管理员权限运行命令,通常用于在 Linux 系统中运行需要管理员权限的命令。

docker:Docker 命令行工具。

commit:提交 Docker 镜像的命令。

-a:指定镜像的作者,这里是作者的名字: yjw。

e007d8b7e1b7:docker的容器id。

my_projectv2:v2:要新创建的镜像的名称和版本号,这里是新建一个名为 my_projectv2:v2的镜像,版本号为 v2。

因此,这条命令将创建一个新的 Docker 镜像,名为 my_projectv2:v2,并将它提交到 Docker 仓库中。

29.png


(3)将镜像打包

docker save -o my_projectv2.tar my_projectv2

30.png


docker:Docker 命令行工具。

save:将 Docker 镜像保存为文件的命令。

~

-o : 参数表示指定输出文件的路径和名称,这个路径是相对于当前工作目录的路径。如果当前工作目录是 /etc/docker,那么 my_projectv2.tar 文件会被保存到 /etc/docker/my_projectv2.tar , 如上图所示。

~

my_projectv2:v2 :要保存的 Docker 镜像的名称和版本号,这里是一个名为 my_projectv2的镜像,版本号为 v2。

(注意:我没加版本号也执行了,是因为我镜像名称是唯一的,不存在相同的版本号,因此命令没有加:v2不会出错)

因此,这条命令将把名为 my_projectv2、版本号为 v2 的 Docker 镜像保存为一个名为 my_projectv2.tar 的文件。

(4)将镜像包压缩

 sudo tar -zcvf my_projectv2.tar.gz my_projectv2.tar

32.png

33.png

还有一种容器的打包和压缩一步到位的方法:

docker save my_projectv2:v2 | gzip > my_projectv2.tar.gz

2. docker镜像压缩包解压及镜像载入 (移动到自己想要运行的服务器)

(1)压缩包解压

通过finalshell或者其它方式,把前面步骤压缩的镜像压缩包给上传到内网服务器指令目录
(注意:我这里只是模仿步骤。有什么出入请指正)

tar -zxvf mask_detection_v5.tar.gz

得到.tar格式的镜像包

34.png


(2)镜像载入

sudo docker load -i my_projectv2.tar

35.png

载入后利用 (比如想要修改加载的镜像,可以参阅后面的一、二、…五等步骤

sudo docker images

查看已存在的镜像。

(3)启动镜像-运行项目

docker run -d -it -p 8888:8888 --restart always --name my_dockerv2 my_projectv2:v2

或者 (-p 8888:8888 端口号的前后书写顺序没有关系,但是建议使用第一个 )
docker run -d -it --restart always --name my_dockerv2 -p 8888:8888 my_projectv2:v2

36.png

(4)启动镜像-项目成功

37.png

(5)docker停止容器(停止项目)

① 先查看所有正在运行中的容器

docker ps

38.png

② docker stop 容器id 停止容器

39.pngPS:某些情况下需要强制关闭,可以使用 docker kill 容器ID

(6)再次启动容器

docker start my_dockerv2

注意:执行启动命令后,后台运行项目环境需要花时间,因此使用IP地址访问时需要花时间等待才能够访问成功

40.pngPS:因为docker run 属于创建新容器并运行,我只是启动已有的容器,故不使用docker run xxx。
而 docker start 命令用于启动一个已经存在的容器

————————————————

本文系转载,版权归原作者所有,如若侵权请联系我们进行删除!  

云掣基于多年在运维领域的丰富时间经验,编写了《云运维服务白皮书》,欢迎大家互相交流学习:

《云运维服务白皮书》下载地址:https://fs80.cn/v2kbbq

想了解更多大数据运维托管服务、数据库运维托管服务、应用系统运维托管服务的的客户,欢迎点击云掣官网沟通咨询:https://yunche.pro/?t=shequ

相关文章

【Linux】进程状态

【Linux】进程状态

一、进程三状态转换·新建态:操作系统已经分配了资源给进程了。·就绪态:已经具备了执行的所有必有的条件,但是由于各种原因,暂时无法运行,进程进入就绪状态。·运行状态:当进程处于调度队列当中的时候就处于运...

【网络】NAT、代理服务、内网穿透(1)

【网络】NAT、代理服务、内网穿透(1)

1.NAT技术NAT(Network Address Translation,网络地址转换)技术,是解决IP地址不足的主要手段,并且能够有效地避免来自网络外部的攻击,隐藏并保护网络内部的计算机。1.1...

Docker:技术架构的演进之路(下)

Docker:技术架构的演进之路(下)

冷热分离架构六、冷热分离架构为了进一步提高系统的并发性能,系统进入冷热分离架构阶段。在这个阶段,引入缓存,实现冷热分离。将热点数据放入缓存中,冷数据放入数据库中,实现数据库的快速响应。这种架构的优点是...

Docker——Windows版本Docker安装

Docker——Windows版本Docker安装

一、简介一、简介  1.1 Docker如何解决大型项目依赖关系复杂,不同组件依赖的兼容性问题?Docker允许开发中将应用、依赖、函数库、配置一起打包,形成可移植镜像Docker应用运行在...

Docker:容器化和虚拟化

Docker:容器化和虚拟化

虚拟化虚拟化是一种资源管理技术,它将计算机的各种实体资源(如CPU、内存、磁盘空间、网络适配器等)予以抽象、转换后呈现出来,并可供分割、组合为一个或多个电脑配置环境。这些资源的新虚拟部分是不受现有资源...

Linux--多路转接之epoll

Linux--多路转接之epoll

epoll 是 Linux 下多路复用 I/O 接口 select/poll 的增强版本,它能显著提高程序在大量并发连接中只有少量活跃的情况下的系统 CPU 利用率。它是 Linux 下多路复用 AP...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。