Add the image chapter
parent
af33005a6b
commit
096fcda9fd
|
@ -0,0 +1,46 @@
|
||||||
|
#Docker image详细介绍
|
||||||
|
|
||||||
|
在之前的介绍中,我们知道docker images是docker的三大组件之一。
|
||||||
|
|
||||||
|
docker把下载的images存储到docker主机上,如果一个image不在主机上,docker会从一个镜像仓库下载,默认的仓库是 DOCKER HUB 公共仓库。
|
||||||
|
|
||||||
|
接下来将介绍更多关于docker images的内容,包括:
|
||||||
|
* 使用和管理本地主机上的images
|
||||||
|
* 创建一个基础的images
|
||||||
|
* 上传images到docker hub(公共images仓库)
|
||||||
|
* 列出本地主机上已经存在的images
|
||||||
|
|
||||||
|
使用 docker images 显示本机上的images
|
||||||
|
```
|
||||||
|
$ sudo docker images
|
||||||
|
REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE
|
||||||
|
training/webapp latest fc77f57ad303 3 weeks ago 280.5 MB
|
||||||
|
ubuntu 13.10 5e019ab7bf6d 4 weeks ago 180 MB
|
||||||
|
ubuntu saucy 5e019ab7bf6d 4 weeks ago 180 MB
|
||||||
|
ubuntu 12.04 74fe38d11401 4 weeks ago 209.6 MB
|
||||||
|
ubuntu precise 74fe38d11401 4 weeks ago 209.6 MB
|
||||||
|
ubuntu 12.10 a7cf8ae4e998 4 weeks ago 171.3 MB
|
||||||
|
ubuntu quantal a7cf8ae4e998 4 weeks ago 171.3 MB
|
||||||
|
ubuntu 14.04 99ec81b80c55 4 weeks ago 266 MB
|
||||||
|
ubuntu latest 99ec81b80c55 4 weeks ago 266 MB
|
||||||
|
ubuntu trusty 99ec81b80c55 4 weeks ago 266 MB
|
||||||
|
ubuntu 13.04 316b678ddf48 4 weeks ago 169.4 MB
|
||||||
|
ubuntu raring 316b678ddf48 4 weeks ago 169.4 MB
|
||||||
|
ubuntu 10.04 3db9c44f4520 4 weeks ago 183 MB
|
||||||
|
ubuntu lucid 3db9c44f4520 4 weeks ago 183 MB
|
||||||
|
```
|
||||||
|
|
||||||
|
当我们启动一个使用这个image的容器时,docker会从docker hub下载它。在列出信息中,我们可以看到3个字段信息
|
||||||
|
|
||||||
|
* 来自于哪个仓库,比如ubuntu
|
||||||
|
* image的标记,比如 14.04
|
||||||
|
* 它的ID号
|
||||||
|
|
||||||
|
一个仓库可能有一个images的都个发行版,比如ubuntu,他们有10.04 12.04 12.10 13.04 14.04,每个发行版的标记都不同,可以使用tag命令来指定images
|
||||||
|
使用一个images的标记来启动容器
|
||||||
|
```
|
||||||
|
$ sudo docker run -t -i ubuntu:14.04 /bin/bash
|
||||||
|
$ sudo docker run -t -i ubuntu:12.04 /bin/bash
|
||||||
|
```
|
||||||
|
|
||||||
|
如果你不指定具体的发行版,比如仅使用ubuntu,那么docker会使用最新的发行版ubuntu:latest。
|
114
image/create.md
114
image/create.md
|
@ -0,0 +1,114 @@
|
||||||
|
##创建我们自己的images
|
||||||
|
别人的镜像虽然好,但不一定适合我们。我们可以对他们做一些改变,有2个方法:
|
||||||
|
###第一个方法:使用docker commit 来扩展一个image
|
||||||
|
先使用image启动容器,更新后提交结果到新的image。
|
||||||
|
```
|
||||||
|
$ sudo docker run -t -i training/sinatra /bin/bash
|
||||||
|
root@0b2616b0e5a8:/#
|
||||||
|
```
|
||||||
|
注意:记住容器的ID ,稍后我们还会用到
|
||||||
|
|
||||||
|
这里我们在容器中添加json gem
|
||||||
|
```
|
||||||
|
root@0b2616b0e5a8:/# gem install json
|
||||||
|
```
|
||||||
|
当结束后,我们使用exit来退出,现在我们的容器已经被我们改变了,使用docker commint命令来提交相应的副本。
|
||||||
|
```
|
||||||
|
$ sudo docker commit -m="Added json gem" -a="Kate Smith" 0b2616b0e5a8 ouruser/sinatra:v2
|
||||||
|
4f177bd27a9ff0f6dc2a830403925b5360bfe0b93d476f7fc3231110e7f71b1c
|
||||||
|
```
|
||||||
|
-m 来指定提交的信息,跟我们使用的版本控制工具一样。
|
||||||
|
-a 可以指定我们更新的用户信息指定我们要从哪个容器ID来创建我们的副本,最后指定目标image的名字。
|
||||||
|
这个例子里面,我们指定了一个新用户,ouruser,使用了sinatra的image,最后指定了image的标记v2。
|
||||||
|
|
||||||
|
使用docker images来查看我们创建的新image。
|
||||||
|
```
|
||||||
|
$ sudo docker images
|
||||||
|
REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE
|
||||||
|
training/sinatra latest 5bc342fa0b91 10 hours ago 446.7 MB
|
||||||
|
ouruser/sinatra v2 3c59e02ddd1a 10 hours ago 446.7 MB
|
||||||
|
ouruser/sinatra latest 5db5f8471261 10 hours ago 446.7 MB
|
||||||
|
```
|
||||||
|
使用新的image来启动容器
|
||||||
|
```
|
||||||
|
$ sudo docker run -t -i ouruser/sinatra:v2 /bin/bash
|
||||||
|
root@78e82f680994:/#
|
||||||
|
```
|
||||||
|
###第二个办法:从dockerfile 来创建 image
|
||||||
|
使用docker commit 来扩展一个image比较简单,但它不容易在一个团队中分享它。我们使用docker build 来创建一个新的image。为此,我们需要创建一个dockerfile,包含一些如何创建我们的image的指令
|
||||||
|
|
||||||
|
现在,我们来创建一个目录和一个dockerfile
|
||||||
|
```
|
||||||
|
$ mkdir sinatra
|
||||||
|
$ cd sinatra
|
||||||
|
$ touch Dockerfile
|
||||||
|
```
|
||||||
|
每一条指令都创建一个image的新的一层,下面是一个简单的例子:
|
||||||
|
```
|
||||||
|
# This is a comment
|
||||||
|
FROM ubuntu:14.04
|
||||||
|
MAINTAINER Kate Smith <ksmith@example.com>
|
||||||
|
RUN apt-get -qq update
|
||||||
|
RUN apt-get -qqy install ruby ruby-dev
|
||||||
|
RUN gem install sinatra
|
||||||
|
```
|
||||||
|
* 使用#来注释
|
||||||
|
* FROM指令告诉docker 使用哪个image源,
|
||||||
|
* 接着是维护者的信息
|
||||||
|
* 最后,我们指定了3条run指令。每一条run指令在image执行一条命令,比如安装一个软件包,在这里我们使用apt 来安装了一些软件
|
||||||
|
现在,让我们来使用docker build来通过dockerfile创建image
|
||||||
|
```
|
||||||
|
$ sudo docker build -t="ouruser/sinatra:v2" .
|
||||||
|
Uploading context 2.56 kB
|
||||||
|
Uploading context
|
||||||
|
Step 0 : FROM ubuntu:14.04
|
||||||
|
---> 99ec81b80c55
|
||||||
|
Step 1 : MAINTAINER Kate Smith <ksmith@example.com>
|
||||||
|
---> Running in 7c5664a8a0c1
|
||||||
|
---> 2fa8ca4e2a13
|
||||||
|
Removing intermediate container 7c5664a8a0c1
|
||||||
|
Step 2 : RUN apt-get -qq update
|
||||||
|
---> Running in b07cc3fb4256
|
||||||
|
---> 50d21070ec0c
|
||||||
|
Removing intermediate container b07cc3fb4256
|
||||||
|
Step 3 : RUN apt-get -qqy install ruby ruby-dev
|
||||||
|
---> Running in a5b038dd127e
|
||||||
|
Selecting previously unselected package libasan0:amd64.
|
||||||
|
(Reading database ... 11518 files and directories currently installed.)
|
||||||
|
Preparing to unpack .../libasan0_4.8.2-19ubuntu1_amd64.deb ...
|
||||||
|
Setting up ruby (1:1.9.3.4) ...
|
||||||
|
Setting up ruby1.9.1 (1.9.3.484-2ubuntu1) ...
|
||||||
|
Processing triggers for libc-bin (2.19-0ubuntu6) ...
|
||||||
|
---> 2acb20f17878
|
||||||
|
Removing intermediate container a5b038dd127e
|
||||||
|
Step 4 : RUN gem install sinatra
|
||||||
|
---> Running in 5e9d0065c1f7
|
||||||
|
. . .
|
||||||
|
Successfully installed rack-protection-1.5.3
|
||||||
|
Successfully installed sinatra-1.4.5
|
||||||
|
4 gems installed
|
||||||
|
---> 324104cde6ad
|
||||||
|
Removing intermediate container 5e9d0065c1f7
|
||||||
|
Successfully built 324104cde6ad
|
||||||
|
```
|
||||||
|
使用-t标记来指定新的image的用户信息和命令
|
||||||
|
使用了.来指出dockerfile的位置在当前目录
|
||||||
|
注意:你也可以指定一个dockfile的路径
|
||||||
|
我们可以看到build进程在执行操作。它要做的第一件事情就是上传这个dockfile内容,因为所有的操作都要依据它来进行。
|
||||||
|
然后,我们看到dockfile中的指令被一条一条的执行。每一步都创建了一个新的容器,在容器中执行指令并提交就跟之前介绍过的docker commit一样。当所有的指令都执行完毕之后,返回了一个image id,并且所有的中间步骤所产生的容器都被删除和清理了。
|
||||||
|
注意:一个image不能超过127层
|
||||||
|
|
||||||
|
从我们新建的images开启容器
|
||||||
|
```
|
||||||
|
$ sudo docker run -t -i ouruser/sinatra:v2 /bin/bash
|
||||||
|
root@8196968dac35:/#
|
||||||
|
$ sudo docker tag 5db5f8471261 ouruser/sinatra:devel
|
||||||
|
```
|
||||||
|
用tag命令标记新的images
|
||||||
|
```
|
||||||
|
$ sudo docker images ouruser/sinatra
|
||||||
|
REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE
|
||||||
|
ouruser/sinatra latest 5db5f8471261 11 hours ago 446.7 MB
|
||||||
|
ouruser/sinatra devel 5db5f8471261 11 hours ago 446.7 MB
|
||||||
|
ouruser/sinatra v2 5db5f8471261 11 hours ago 446.7 MB
|
||||||
|
```
|
|
@ -0,0 +1,8 @@
|
||||||
|
##下载images
|
||||||
|
现在我们指定了一个image,training/sinatra,我们可以使用docker pull命令来下载它
|
||||||
|
```
|
||||||
|
$ sudo docker pull training/sinatra
|
||||||
|
然后我们就可以使用这个image来启动容器了
|
||||||
|
$ sudo docker run -t -i training/sinatra /bin/bash
|
||||||
|
root@a8cb6ce02d85:/#
|
||||||
|
```
|
16
image/get.md
16
image/get.md
|
@ -0,0 +1,16 @@
|
||||||
|
##获取images
|
||||||
|
|
||||||
|
我们如何获取新的images呢?当我们启动容器使用的image不再本地主机上时,docker会自动下载他们。这很耗时,我们可以使用docker pull命令来预先下载我们需要的image。下面的例子下载一个centos镜像。
|
||||||
|
```
|
||||||
|
$ sudo docker pull centos
|
||||||
|
Pulling repository centos
|
||||||
|
b7de3133ff98: Pulling dependent layers
|
||||||
|
5cc9e91966f7: Pulling fs layer
|
||||||
|
511136ea3c5a: Download complete
|
||||||
|
ef52fb1fe610: Download complete
|
||||||
|
```
|
||||||
|
我们可以看到下载的image的每一个层次,这样当我们使用这个image来启动容器的时候,它就可以马上启动了。
|
||||||
|
```
|
||||||
|
$ sudo docker run -t -i centos /bin/bash
|
||||||
|
bash-4.1#
|
||||||
|
```
|
|
@ -0,0 +1,7 @@
|
||||||
|
##使用docker push上传images
|
||||||
|
```
|
||||||
|
$ sudo docker push ouruser/sinatra
|
||||||
|
The push refers to a repository [ouruser/sinatra] (len: 1)
|
||||||
|
Sending image list
|
||||||
|
Pushing repository ouruser/sinatra (3 tags)
|
||||||
|
```
|
10
image/rmi.md
10
image/rmi.md
|
@ -0,0 +1,10 @@
|
||||||
|
##用dcoker rmi 移除本地images
|
||||||
|
```
|
||||||
|
$ sudo docker rmi training/sinatra
|
||||||
|
Untagged: training/sinatra:latest
|
||||||
|
Deleted: 5bc342fa0b91cabf65246837015197eecfa24b2213ed6a51a8974ae250fedd8d
|
||||||
|
Deleted: ed0fffdcdae5eb2c3a55549857a8be7fc8bc4241fb19ad714364cbfd7a56b22f
|
||||||
|
Deleted: 5c58979d73ae448df5af1d8142436d81116187a7633082650549c52c3a2418f0
|
||||||
|
```
|
||||||
|
|
||||||
|
*注意:在删除images之前要先用docker rm 删掉依赖于这个images的容器
|
|
@ -0,0 +1,21 @@
|
||||||
|
##查找images
|
||||||
|
|
||||||
|
docker的一个特点是很多人因为各种不同的用途创建了各种不同的images。它们都被上传到了docker hub共有仓库上,我们可以在docker hub的网站上来查找它们。使用docker search命令。比如,当我们的团队需要ruby和sinatra作为web应用程序的开发时,我们使用docker search 来搜索合适的image,使用关键字sinatra
|
||||||
|
|
||||||
|
```
|
||||||
|
$ sudo docker search sinatra
|
||||||
|
NAME DESCRIPTION STARS OFFICIAL AUTOMATED
|
||||||
|
training/sinatra Sinatra training image 0 [OK]
|
||||||
|
marceldegraaf/sinatra Sinatra test app 0
|
||||||
|
mattwarren/docker-sinatra-demo 0 [OK]
|
||||||
|
luisbebop/docker-sinatra-hello-world 0 [OK]
|
||||||
|
bmorearty/handson-sinatra handson-ruby + Sinatra for Hands on with D... 0
|
||||||
|
subwiz/sinatra 0
|
||||||
|
bmorearty/sinatra 0
|
||||||
|
```
|
||||||
|
|
||||||
|
我们看到返回了很多包含sinatra的images。其中包括image名字、描述、星级(表示该image的受欢迎程度)、是否官方创建、是否自动创建。官方的images是stackbrew项目组创建和维护的,autimated 资源允许你验证image的来源和内容。
|
||||||
|
|
||||||
|
现在我们已经回顾了可用的images,并决定使用training/sinatra镜像。到目前为止,我们看到了2种images 资源。比如ubuntu,被称为基础或则根镜像。这些基础镜像是docker公司创建、验证、支持、提供。他们往往使用一个单词作为他们的名字。
|
||||||
|
|
||||||
|
还有一种类型,比如我们选择的training/sinatra镜像。它是由docker的用户创建并维护的,你可以通过指定image名字的前缀来指定他们,比如training。
|
Loading…
Reference in New Issue