前言
Docker 是一个开源软件,也是一个开放平台,用于开发应用、交付(shipping)应用、运行应用。 Docker允许用户将基础设施(Infrastructure)中的应用单独分割出来,形成更小的颗粒(容器),从而提高交付软件的速度。

本文简要介绍如何将Docker容器打包成镜像并提交到Docker仓库。
前提条件
确保已经安装并正确配置了 Docker 环境。
如果你要将镜像推送到 Docker 仓库,需要有对应的仓库账号,并已经登录到该仓库。登录 Docker Hub 的命令示例如下:
bash
docker login
具体步骤
将正在运行或已停止的 Docker 容器打包成镜像并提交到 Docker 仓库,可按以下步骤操作:
1. 查看当前容器
使用以下命令查看当前正在运行的容器列表:
bash
docker ps
如果想查看所有容器(包括已停止的),可以使用:
bash
docker ps -a
2. 将容器打包成镜像
使用 docker commit
命令将容器打包成镜像。该命令的基本语法如下:
bash
docker commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]]
参数说明:
- OPTIONS:可选参数,例如 -m 用于添加提交信息,-a 用于指定作者信息。
- CONTAINER:要打包的容器的 ID 或名称。
- REPOSITORY[:TAG]:目标镜像的名称和标签。如果不指定标签,默认为 latest。
示例:
bash
docker commit -m "Create image from container" -a "Your Name" my-container my-image:1.0
上述命令将名为 my-container 的容器打包成名为 my-image、标签为 1.0 的镜像,并添加了提交信息和作者信息。
3. 验证镜像是否创建成功
使用以下命令查看本地镜像列表:
bash
docker images
在输出中应该能看到新创建的镜像 my-image:1.0。
4. (可选)为镜像添加仓库地址标签
如果你要将镜像推送到 Docker 仓库,需要为镜像添加包含仓库地址的标签。例如,如果你要推送到 Docker Hub,标签格式通常为 username/repository:tag;如果是私有仓库,标签格式为 your-registry-address/username/repository:tag。
bash
docker tag my-image:1.0 your-dockerhub-username/my-image:1.0
或者对于私有仓库:
bash
docker tag my-image:1.0 your-private-registry:5000/my-image:1.0
5. 将镜像推送到仓库
使用 docker push 命令将镜像推送到指定的仓库:
推送到 Docker Hub:
bash
docker push your-dockerhub-username/my-image:1.0
推送到私有仓库:
bash
docker push your-private-registry:5000/my-image:1.0
注意事项
docker commit
方式适合快速创建镜像,但它只是保存了容器的当前状态,不会记录容器构建过程中的操作步骤。如果需要可重复构建和更好的版本管理,建议使用 Dockerfile 来构建镜像。- 在推送镜像到 Docker 仓库时,要确保网络连接正常,并且有足够的权限进行推送操作。
版权说明
本文为原创文章,部分内容基于GPT工具撰写,独家发布在blog.csdn.net/TracelessLe。未经个人允许不得转载。如需帮助请email至tracelessle@163.com或扫描个人介绍栏二维码咨询。
参考资料
[2] Docker官方文档