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 从导出的本地文件中再导入到本地镜像库,例如



这将导入镜像以及其相关的元数据信息(包括标签等)


results matching ""

    No results matching ""