docker将容器打包提交为镜像,再打包成tar包

将容器打包成镜像可以通过以下步骤来实现。这里以 Docker 为例,假设你已经安装了 Docker 并且有一个正在运行的容器。

1. 找到正在运行的容器

首先,你需要找到你想要打包成镜像的容器的 ID 或者名字。可以使用以下命令查看所有正在运行的容器:

docker ps

2. 提交容器为镜像

使用 docker commit 命令将容器的当前状态提交为一个新的镜像。命令格式如下:

docker commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]]

例如,假设你有一个容器 ID 为 abc123def456,你想将其保存为一个名为 my_image 的镜像:

docker commit abc123def456 my_image

你也可以为镜像指定一个标签:

docker commit abc123def456 my_image:v1

3. 验证镜像

提交完成后,你可以使用以下命令查看新创建的镜像:

docker images

4. 运行新镜像

为了确保你的新镜像可以正常工作,你可以运行一个基于此镜像的新容器:

docker run -it my_image

5. (可选)推送镜像到远程仓库

如果你想将这个镜像推送到 Docker Hub 或其他 Docker 镜像仓库,可以使用 docker push 命令。首先,你需要登录到你的 Docker Hub 账户:

docker login

然后,推送镜像:

docker push my_image:v1

以上步骤简要说明了如何将一个正在运行的容器打包成镜像,并推送到远程仓库。这是一个常见的工作流程,用于保存和分发容器的当前状态。

如果你想把镜像打包成一个tar包

将 Docker 镜像打包成一个 tar 包可以使用 docker save 命令。以下是具体步骤:

1. 找到你想要打包的镜像

首先,你需要确认你想要打包的镜像的名字或 ID。可以使用以下命令查看所有本地镜像:

docker images

2. 保存镜像为 tar 包

使用 docker save 命令将镜像保存为一个 tar 文件。命令格式如下:

docker save -o [输出文件名] [镜像名字:标签]

例如,假设你有一个名为 my_image 的镜像,并且你想将其保存为 my_image.tar 文件:

docker save -o my_image.tar my_image

你也可以包括镜像标签:

docker save -o my_image_v1.tar my_image:v1

3. 验证 tar 包

保存完成后,你可以在输出文件所在目录下找到生成的 tar 文件。例如,你可以使用以下命令列出当前目录的内容来验证:

ls -lh my_image.tar

4. 导入 tar 包中的镜像(可选)

如果你需要在另一个 Docker 主机上使用这个镜像,可以使用 docker load 命令从 tar 文件中导入镜像:

docker load -i my_image.tar

docker images

docker run -d --name jt1 -v /etc/localtime:/etc/localtime:ro -v /home/HwHiAiUser/jt_ascend:/home/jt -e ASCEND_VISIBLE_DEVICES=0 84403346c983 tail -f /dev/null

这将会在新主机上加载该镜像,你可以使用 docker images 命令查看导入的镜像。

总结

以上步骤详细说明了如何将 Docker 镜像保存为一个 tar 包文件,并且如何在需要时导入这个 tar 包中的镜像。这个方法非常适合用于备份、迁移和分发 Docker 镜像。

因为镜像tar包大于4G,所以采用分块的方式进行存储

执行以下命令:split -b 1000M -d -a 1 目标.tar

会分割成 5个文件:

可以在用 cat x* >test.tar #合并文件

相关推荐
水宝的滚动歌词1 小时前
K8S单节点部署及集群部署
云原生·容器·kubernetes
ly49832 小时前
docker--工作目录迁移
docker·容器·eureka
yohoo菜鸟3 小时前
kubernetes简单入门实战
云原生·容器·kubernetes
不会编程的懒洋洋3 小时前
Spring Cloud Eureka 服务注册与发现
java·笔记·后端·学习·spring·spring cloud·eureka
Lyqfor7 小时前
云原生学习
java·分布式·学习·阿里云·云原生
李少兄8 小时前
Docker 命令总结:从入门到入土
docker·容器·eureka
Smile丶凉轩10 小时前
微服务即时通讯系统的实现(客户端)----(1)
微服务·云原生·架构
南慕小白10 小时前
云原生后端
云原生
小安运维日记11 小时前
CKA认证 | Day3 K8s管理应用生命周期(上)
运维·云原生·容器·kubernetes·云计算·k8s
politeboy13 小时前
关于k8s中镜像的服务端口被拒绝的问题
云原生·容器·kubernetes