Docker 简介
Docker 可以从 Dockerfile
中读取指令自动构建镜像。Dockerfile
是一个文本文件,它包含了用户可以在Termial
执行的所有命令去构建镜像。用户使用Docker build
可以通过执行一系列连续的命令自动构建镜像。
这篇文章描述了你可以在Dockerfile
中使用的命令。可以参考 Dockerfile
Best Practices 作为学习指南。
用法
Docker build
命令通过Dockerfile
和context
编译镜像,context
是在PATH
或 URL
中指定的一系列文件,PATH
是本地文件系统中的一个目录,URL
是一个 git
仓库地址.
context
是递归处理的。所以PATH
包括一些子目录,URL
包含repository
和它的submodules
这个例子展示了一个编译命令使用当前目录作为context
$ docker build .
Sending build context to Docker daemon 6.51 MB
...
编译时在Docker Daemon
中运行,而不是CLI
。一个编译进程的第一件事是发送全部context
(递归的) 到daemon
。在大多数情况下,最好使用一个空目录作为context
并且保存Dockerfile
在该目录中。添加仅在编译Dockerfile
中使用的文件到该目录
Waring: 不要使用根目录
/
作为PATH
,因为它将导致编译时将你硬盘的所有文件发送给服务器。
为了在编译的时候使用一个文件,Dockerfile
会在一个指令中指定关联的文件。例如:一个copy
指令。为了提高性能可以通过增加.dockerignore
文件来排除context
中的目录和文件。对于如何创建. dockerignore
文件可以参考这篇文章
一般说来Dockerfile
存储在context
的根目录,你也可以通过docker build
的-f
参数来指定在你文件系统任意位置的Dockerfile
。
$ docker build -f /path/to/a/Dockerfile .
你也可以指定编译成功后保存新的镜像的repository
和tag
.
$ docker build -t shykes/myapp .
为了编译后保存镜像到多个位置,当执行build
命令时可以指定多个-t
参数
$ docker build -t shykes/myapp:1.0.2 -t shykes/myapp:latest .
在docker daemon
执行Dockerfile
中的指令之前,它会对Dockerfile
做一个初步的验证如果有语法错误它会返回一个error
$ docker build -t test/myapp .
Sending build context to Docker daemon 2.048 kB
Error response from daemon: Unknown instruction: RUNCMD
Docker daemon
逐个执行Dockerfile
中的指令,在最后输出你的镜像ID
之前,如果必要它会提交每个指令的结果到新的镜像。Docker deamon
会自动清除你发送的context
。
既然每个命令时单独执行的,并去建立一个新的镜像,所以RUN cd /tmp
对下个指令不会产生任何影响。
Docker
会尽可能的重用中间镜像(缓存),去加速docker build
进程,这也就是在console
输出中展示的Using cache
信息。(更多的信息请参考docker
最佳实践中的build cache section)
$ docker build -t svendowideit/ambassador .
Sending build context to Docker daemon 15.36 kB
Step 1/4 : FROM alpine:3.2
---> 31f630c65071
Step 2/4 : MAINTAINER SvenDowideit@home.org.au
---> Using cache
---> 2a1c91448f5f
Step 3/4 : RUN apk update && apk add socat && rm -r /var/cache/
---> Using cache
---> 21ed6e7fbb73
Step 4/4 : CMD env | grep _TCP= | (sed 's/.*_PORT_\([0-9]*\)_TCP=tcp:\/\/\(.*\):\(.*\)/socat -t 100000000 TCP4-LISTEN:\1,fork,reuseaddr TCP4:\2:\3 \&/' && echo wait) | sh
---> Using cache
---> 7ea8aef582cc
Successfully built 7ea8aef582cc
从缓存中编译仅限于在本地父链的镜像中,这意味着这些镜像是之前编译的或者整个镜像链是通过dock load
下载的。如果你希望使用某个镜像的缓存你可以通过--cache-from
参数指定。通过--cache-from
指定的镜像不必须又一个本地父链,它也可以是从其他registries
下载的。
当你编译成功后,你可以查看Pushing a repository to its registry
格式
这是一个Dockerfile
的格式:
# Comment
INSTRUCTION arguments
INSTRUCTION
是大小写不敏感的。然而它的惯例是使用大写作为和参数的区分。
Docker
有序的执行Dockerfile
中的指令。一个Dockerfile
必须以一个FROM
指令开始。 FROM
指明了你的镜像从哪个Base Image
开始编译。