Rewrite the content

This commit is contained in:
Baohua Yang
2014-09-12 16:18:24 +08:00
parent e6883a4ef2
commit 71adb73dbb
7 changed files with 68 additions and 45 deletions

View File

@@ -1,28 +1,28 @@
##创建我们自己的images
别人的镜像虽然好,但不一定适合我们。
我们可以对这些镜像做一些修改有2个方法
###第一个方法使用docker commit 来扩展一个image
先使用image启动容器更新后提交结果到新的image
我们可以对这些镜像做一些修改有2个方法利用现成的镜像进行修改或者利用dockerfile创建。
###使用docker commit 来扩展一个image
先使用下载的image启动容器。
```
$ sudo docker run -t -i training/sinatra /bin/bash
root@0b2616b0e5a8:/#
```
注意记住容器的ID ,稍后还会用到
注意记住容器的ID ,稍后还会用到
在容器中添加json和gem两个应用
在容器中添加json和gem两个应用
```
root@0b2616b0e5a8:/# gem install json
```
当结束后我们使用exit来退出现在我们的容器已经被我们改变了使用docker commint命令来提交相应的副本。
当结束后我们使用exit来退出现在我们的容器已经被我们改变了使用docker commint命令来提交更新后的副本。
```
$ sudo docker commit -m="Added json gem" -a="Kate Smith" 0b2616b0e5a8 ouruser/sinatra:v2
$ sudo docker commit -m "Added json gem" -a "Docker Newbee" 0b2616b0e5a8 ouruser/sinatra:v2
4f177bd27a9ff0f6dc2a830403925b5360bfe0b93d476f7fc3231110e7f71b1c
```
-m 来指定提交的信息,跟我们使用的版本控制工具一样。
-a 可以指定我们更新的用户信息指定我们要从哪个容器ID来创建我们的副本最后指定目标image的名字。
这个例子里面我们指定了一个新用户ouruser使用了sinatra的image最后指定了image的标记v2。
其中,-m 来指定提交的说明信息,跟我们使用的版本控制工具一样-a 可以指定更新的用户信息之后是用来创建镜像的容器的ID最后指定目标image的仓库名和tag信息。创建成功后会返回这个image的id信息
使用docker images来查看我们创建的新image。
使用docker images来查看新创建的image。
```
$ sudo docker images
REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE
@@ -30,34 +30,38 @@ 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来启动容器
之后,可以使用新的image来启动容器
```
$ sudo docker run -t -i ouruser/sinatra:v2 /bin/bash
root@78e82f680994:/#
```
###第二个办法从dockerfile 来创建 image
使用docker commit 来扩展一个image比较简单但它不容易在一个团队中分享它。我们使用docker build 来创建一个新的image。为此我们需要创建一个dockerfile包含一些如何创建我们的image的指令
现在我们来创建一个目录和一个dockerfile
###利用dockerfile 来创建 image
使用`docker commit` 来扩展一个image比较简单但它不容易在一个团队中分享它。我们可以使用`docker build` 来创建一个新的image。为此首先需要创建一个dockerfile包含一些如何创建image的指令。
新建一个目录和一个dockerfile
```
$ mkdir sinatra
$ cd sinatra
$ touch Dockerfile
```
每一条指令都创建一个image的新的一层,下面是一个简单的例子
Dockerfile中每一条指令都创建image的一层例如
```
# This is a comment
FROM ubuntu:14.04
MAINTAINER Kate Smith <ksmith@example.com>
MAINTAINER Docker Newbee <newbee@docker.com>
RUN apt-get -qq update
RUN apt-get -qqy install ruby ruby-dev
RUN gem install sinatra
```
Dockerfile基本的语法是
* 使用#来注释
* FROM指令告诉docker 使用哪个image源,
* FROM指令告诉docker 使用哪个image作为源image
* 接着是维护者的信息
* 最后我们指定了3条run指令。每一条run指令在image执行一条命令,比如安装一个软件包,在这里我们使用apt 来安装了一些软件
现在让我们来使用docker build来通过dockerfile创建image
* RUN开头的指令会在创建中运行比如安装一个软件包在这里使用apt 来安装了一些软件
编写完成Dockerfile后可以使用docker build来生成image。
```
$ sudo docker build -t="ouruser/sinatra:v2" .
Uploading context 2.56 kB
@@ -92,24 +96,26 @@ Successfully installed sinatra-1.4.5
Removing intermediate container 5e9d0065c1f7
Successfully built 324104cde6ad
```
使用-t标记来指定新的image的用户信息和命令
使用了.来指出dockerfile的位置在当前目录
注意你也可以指定一个dockfile的路径
我们可以看到build进程在执行操作。它要做的第一件事情就是上传这个dockfile内容因为所有的操作都要依据它来进行。
然后我们看到dockfile中的指令被一条一条的执行。每一步都创建了一个新的容器在容器中执行指令并提交就跟之前介绍过的docker commit一样。当所有的指令都执行完毕之后返回了一个image id并且所有的中间步骤所产生的容器都被删除和清理了。
注意一个image不能超过127层
其中-t标记来添加tag指定新的image的用户信息
.是Dockerfile所在的路径当前目录也可以替换为一个具体的Dockerfile的路径。
我们新建的images开启容器
我们可以看到build进程在执行操作。它要做的第一件事情就是上传这个Dockerfile内容因为所有的操作都要依据Dockerfile来进行。
然后dockfile中的指令被一条一条的执行。每一步都创建了一个新的容器在容器中执行指令并提交修改就跟之前介绍过的`docker commit`一样。当所有的指令都执行完毕之后返回了最终的image id。所有的中间步骤所产生的容器都被删除和清理了。
*注意一个image不能超过127层
现在可以利用新创建的images来启动一个容器。
```
$ sudo docker run -t -i ouruser/sinatra:v2 /bin/bash
root@8196968dac35:/#
```
还可以用tag命令来修改images的tag。
```
$ 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
```
```