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
是那个
I.使用和管理本地主机上的 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
或
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
从导出的本地文件中再导入到本地镜像库,例如
或
这将导入镜像以及其相关的元数据信息(包括标签等)