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

冉升10个月前行业资讯1449

背景

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

相关文章

一个初级运维工程师对于运维工作的一些浅显认知

一个初级运维工程师对于运维工作的一些浅显认知

最近因为部门架构调整,之前工作做了交接,新的安排又没有确定,领导建议学习下JAVA开发,后续直接参与到研发工作中而不再负责运维工作。周围同事也都在说运维工作比较low,转研发会好一些。但是毕竟从毕业之...

Docker:技术架构的演进之路

Docker:技术架构的演进之路

前言技术架构是指在软件开发和系统构建中,为了满足业务需求和技术要求,对系统的整体结构、组件、接口、数据流以及技术选型等方面进行的详细设计和规划。它是软件开发过程中的重要组成部分,为开发团队提供了明确的...

从传统运维到SRE的转型路线

从传统运维到SRE的转型路线

从传统运维向SRE(Site Reliability Engineering)转型需要技术技能、思维方式和工作模式的全面转变。以下是详细的转型路线图:一、理解SRE的核心理念SRE的定义SRE是Goo...

Linux 配置Java环境(一)

Linux 配置Java环境(一)

一、配置Java环境1、查看系统是否有java环境输入指令java -version回车即可如图表示Linux系统有自带的jdk,但是这并不是我们想要的,所以得卸载2、卸载系统自带的jdk1 .找到具...

Linux 中通过 cpulimit 限制服务的CPU占用率

Linux 中通过 cpulimit 限制服务的CPU占用率

通常做资源限制有多种方法,比如用 CGroup 方法、system-run等,cpulimit 只是其中的一种方式。安装sudo apt update sud...

Spring AMQP与RabbitMQ深度整合指南:从基础到高级应用(3)

Spring AMQP与RabbitMQ深度整合指南:从基础到高级应用(3)

3.5 声明交换机和队列:在之前我们都是基于RabbitMQ控制台来创建队列、交换机。但是在实际开发时,队列和交换机是程序员定义的,将来项目上线,又要交给运维去创建。那么程序员就需要把程序中运行的所有...

发表评论    

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