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 #合并文件

相关推荐
代码之光_19802 小时前
【微服务架构的守护神】Eureka与服务熔断深度解析
微服务·eureka·架构
青石路2 小时前
不单独部署注册中心,又要具备注册中心的功能,我能上天!
eureka·注册中心
古猫先生2 小时前
2028年企业云存储支出翻倍,达到1280亿美元
人工智能·云原生
lendq12 小时前
k8s-第八节-Helm
云原生·容器·kubernetes
lendq15 小时前
k8s-第三节-工作负载
云原生·容器·kubernetes
科技互联人生16 小时前
云原生技术架构详解
云原生·系统架构
lldhsds16 小时前
Kubernetes云原生存储解决方案openebs部署实践-3.10.0版本(helm部署)
云原生·kubernetes·openebs
研究司马懿1 天前
【云原生】Kubernetes部署高可用平台手册
云原生·容器·kubernetes·k8s·负载均衡·高可用架构
goTsHgo1 天前
Eureka介绍与使用
eureka
The Straggling Crow1 天前
k8s record 20240703
云原生·容器·kubernetes