Docker image详细介绍
在之前的介绍中,我们知道 docker images 是 docker 的三大组件之一。
docker 把下载的 images 存储到 docker 主机上,如果一个 image 不在主机上, docker 会从一个镜像仓库下载,默认的仓库是 DOCKER HUB 公共仓库。
接下来将介绍更多关于 docker images 的内容,包括:
- 使用和管理本地主机上的 images
- 创建一个基础的 images
- 上传 images 到 docker hub (公共 images 仓库)
- 列出本地主机上已经存在的 images
使用 docker images 显示本机上的 images
在列出信息中,
- REPOSITORY:来自于哪个仓库,比如 docker.io\/centos
- TAG的标记,比如 latest
- IMAGE ID:镜像它的 ID 号
- CREATED:创建时间
- SIZE:镜像的 SIZE
一个仓库可能有一个 images 的都个发行版,比如 ubuntu ,他们有 10.04 12.04 12.10 13.04 14.04,每个发行版的标记都不同,可以使用 tag 命令来指定 images 注:如果你不指定具体的发行版,比如仅使用 ubuntu ,那么 docker 会使用最新的发行版 ubuntu:latest 提示:建议最好指定发行版,只有这样你才可以保证你真正使用的 image 是那个
一、使用和管理本地主机上的 images
1、 获取 images
我们如何获取新的 images 呢?当我们启动容器使用的 image 不再本地主机上时, docker 会自动下载他们。这很耗时,我们可以使用 docker pull 命令来预先下载我们需要的 image 。下面的例子下载一个centos 镜像。
这样当我们使用这个 image 来启动容器的时候,它就可以马上启动了。
2 、查找 images
docker 的一个特点是很多人因为各种不同的用途创建了各种不同的 images 。它们都被上传到了docker hub 共有仓库上,我们可以在 docker hub 的网站上来查找它们。使用 docker search 命令。比如,当我们需要 ruby 和 sinatra 作为 web 应用程序的开发时,我们使用 docker search 来搜索合适的image ,使用关键字 sinatra
我们看到返回了很多包含 sinatra 的 images 。其中包括 image 名字、描述、星级(表示该 image 的受欢迎程度)、是否官方创建、是否自动创建。官方的 images 是 stackbrew 项目组创建和维护的,automated 资源允许你验证 image 的来源和内容。
到目前为止,我们看到了 2种 images 资源。比如 ubuntu ,被称为基础或则根镜像。这些基础镜像是 docker 公司创建、验证、支持、提供。他们往往使用一个单词作为他们的名字。还有一种类型,比如我们选择的 training\/sinatra 镜像。它是由 docker 的用户创建并维护的,你可以通过指定 image 名字的前缀来指定他们,比如 training 。
3 、下载 images
现在我们指定了一个 image , training\/sinatra ,我们可以使用 docker pull 命令来下载它
下载过程中,会输出获取镜像的每一层信息。
该命令实际上相当于#docker pull registry.hub.docker.com\/ubuntu:12.04 命令,即从注册服 务器 registry.hub.docker.com 中的 ubuntu 仓库来下载标记为 12.04 的镜像。 有时候官方仓库注册服务器下载较慢,可以从其他仓库下载。 从其它仓库下载时需要指定完整的仓库注册服务器地址。例如
# docker pull dl.dockerpool.com:5000/ubuntu:12.04
查看镜像文件 docker images
查看完整信息
当镜像下载成功后,你可以看到 12 位的 hash 值像 05188b417f30,这是下载完整的镜像的精简 ID,这些短的镜像 ID 是完整镜像 ID 的前 12 个字符--可以使用 docker inspect 或者 docker images --no-trunc 来获得完整的镜像 ID
或
二、创建我们自己的 images
别人的镜像虽然好,但不一定适合我们。我们可以对他们做一些改变,有 2 个方法:
1.第一个方法:使用 docker commit 来扩展一个 image
先使用 image 启动容器,更新后提交结果到新的 image 。
注意:记住容器的 ID ,稍后我们还会用到 在容器中添加mariadb-server应用。
当结束后,我们使用 exit 来退出,现在我们的容器已经被我们改变了 使用 docker commint 命令来提交相应的副本。
其中,
- -m 来指定提交的说明信息,跟我们使用的版本控制工具一样;
- -a 可以指定更新的用户信息;之后是用来创建镜像的容器的 ID;
- 最后指定目标镜像的仓库名和 tag 信息。 创建成功后会返回这个镜像的 ID信息。
- 使用 docker images 来查看新创建的镜像。
- 之后,可以使用新的镜像来启动容器
2.第二个办法:从 dockerfile 来创建 image
使用 docker commit 来扩展一个 image 比较简单,但它不容易在一个团队中分享它。我们使用docker build 来创建一个新的 image 。为此,我们需要创建一个 dockerfile ,包含一些如何创建我们的image 的指令。
- 现在,我们来创建一个目录和一个 dockerfile
- 内容如下:
3.Dockerfile 基本的语法是
使用#来注释
- FROM指令告诉 Docker 使用哪个镜像作为基础(docker 使用哪个 image 源)
- MAINTAINER是维护者的信息
- RUN开头的指令会在创建中运行,比如安装一个软件包,在这里使用 yum 来安装了一些软件
编写完成 Dockerfile 后可以使用 docker build 来生成镜像。
其中
- -t 标记来添加 tag,指定新的镜像的用户信息。
- “.” 是 Dockerfile 所在的路径(当前目录),也可以替换为一个具体的 Dockerfile 的路径。
可以看到 build 进程在执行操作。它要做的第一件事情就是上传这个 Dockerfile 内容,因为所有的操作都要依据 Dockerfile 来进行。 然后,Dockfile 中的指令被一条一条的执行。每一步都创建了一个新的容器,在容器中执行指令并提交修改(就跟之前介绍过的 docker commit 一样)。当所有的指令都执行完毕之后,返回了最终的镜像 id。所有的中间步骤所产生的容器都被删除和清理了。
*注意一个镜像不能超过 127 层
查看生成的镜像
从我们新建的 images 开启容器
还可以用 docker tag 命令来修改镜像的标签。
从本地文件系统导入
要从本地文件系统导入一个镜像,可以使用 openvz(容器虚拟化的先锋技术)的模板来创建: openvz 的模板下载地址为http:\/\/openvz.org\/Download\/template\/precreated。 先下载了一个 centos-6-x86_64.tar.gz的镜像,之后使用以下命令导入:
三、上传镜像
用户可以通过 docker push 命令,把自己创建的镜像上传到仓库中来共享。例如,用户在 Docker Hub 上,完成注册后,可以推送自己的镜像到仓库中。
这里有两种访问可以创建和注册一个 Docker Hub 账户:
1.通过网站
2.通过命令行
你可以通过使用命令行输入 docker login 命令来创建一个 Docker Hub 账号
#docker login
邮箱确认
一旦你填写完毕表格,请查看你的电子邮件,通过点击欢迎信息中的链接来激活您的账户。
基本思路:
首先注册docker的账户,然后使用docker login登录。 使用docker push可以将自己的镜像上传上去了
如果有其他的仓库,例如:
# docker push docker.sina.com.cn:5000/commit
用 dcoker rmi 移除本地 images
docker rmi 镜像名或镜像id
注意:在删除 images 之前要先用 docker rm 删掉依赖于这个 images 的容器
存出和载入镜像
当需要把一台机器上的镜像迁移到另一台机器的时候,需要存出镜像与载入镜像。
存出镜像
如果要导出镜像到本地文件,可以使用 docker save 命令。
载入镜像
可以使用 docker load 从导出的本地文件中再导入到本地镜像库,例如
或
这将导入镜像以及其相关的元数据信息(包括标签等)