Docker image详细介绍


目录




镜像导图

在之前的介绍中,我们知道docker imagesdocker的三大组件之一。

docker把下载的images 存储到 docker主机上,如果一个image不在主机上, docker 会从一个镜像仓库下载,默认的仓库是 DOCKER HUB公共仓库。

接下来将介绍更多关于 docker images的内容,包括:

  • 使用和管理本地主机上的 images
  • 创建一个基础的 images
  • 上传 imagesdocker 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 是那个


I.使用和管理本地主机上的 images

1.获取 images

回顶部

我们如何获取新的 images 呢?当我们启动容器使用的 image 不再本地主机上时, docker 会自动下载他们。这很耗时,我们可以使用 docker pull 命令来预先下载我们需要的image 。下面的例子下载一个centos 镜像

这样当我们使用这个image来启动容器的时候,它就可以马上启动了。

2.查找 images

回顶部

docker 的一个特点是很多人因为各种不同的用途创建了各种不同的images。它们都被上传到了docker hub共有仓库上,我们可以在 docker hub的网站上来查找它们。使用 docker search 命令。比如,当我们需要rubysinatra 作为 web 应用程序的开发时,我们使用 docker search来搜索合适的 image ,使用关键字sinatra

我们看到返回了很多包含 sinatraimages 。其中包括image名字、描述、星级(表示该image 的受欢迎程度)、是否官方创建、是否自动创建。官方的imagesstackbrew项目组创建和维护的,automated资源允许你验证 image 的来源和内容。

到目前为止,我们看到了 2种 images资源。比如 ubuntu ,被称为基础或则根镜像。这些基础镜像是 docker公司创建、验证、支持、提供。他们往往使用一个单词作为他们的名字。还有一种类型,比如我们选择的 training/sinatra镜像。它是由docker的用户创建并维护的,你可以通过指定image名字的前缀来指定他们,比如training

3.下载images

回顶部

现在我们指定了一个imagetraining/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


II.创建自己的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 的模板的 下载地址

先下载了一个 centos-6-x86_64.tar.gz的镜像,之后使用以下命令导入:


III.上传镜像

回顶部

用户可以通过 docker push 命令,把自己创建的镜像上传到仓库中来共享。例如,用户在 Docker Hub上,完成注册后,可以推送自己的镜像到仓库中。

这里有两种访问可以创建和注册一个Docker Hub 账户:

  • 1.通过网站
  • 2.通过命令行

你可以通过使用命令行输入 docker login 命令来创建一个 Docker Hub 账号

#docker login

邮箱确认

一旦你填写完毕表格,请查看你的电子邮件,通过点击欢迎信息中的链接来激活您的账户。

i.上传

回顶部

基本思路:

首先注册docker的账户,然后使用docker login登录。 使用docker push可以将自己的镜像上传上去了

如果有其他的仓库,例如:

# docker push docker.sina.com.cn:5000/commit

用 dcoker rmi 移除本地 images


docker rmi 镜像名或镜像id

注意:在删除images之前要先用docker rm删掉依赖于这个images的容器

ii.存出和载入镜像

回顶部

当需要把一台机器上的镜像迁移到另一台机器的时候,需要存出镜像与载入镜像。

1.存出镜像

回顶部

如果要导出镜像到本地文件,可以使用 docker save 命令。

2.载入镜像

回顶部

可以使用docker load从导出的本地文件中再导入到本地镜像库,例如



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

回顶部


results matching ""

    No results matching ""