# 5. 使用 Dockerfile 文件
#### 1. 介绍
上一篇:[理解docker镜像的层叠结构(四)](https://www.rails365.net/articles/li-jie-docker-jing-xiang-de-ceng-die-jie-gou-si)
Dockerfile是一个纯文本文件,内容是可读的,就是把构建镜像的指令一条条放在这个文件中,然后就可以build出来一个镜像。
#### 2. 使用
我们来实践一下。
创建一个最简单的Dockerfile文件。
```
$ mkdir mynginx
$ cd mynginx
$ touch Dockerfile
```
内容如下:
```
FROM nginx
RUN echo '<h1>Hello, Docker!</h1>' > /usr/share/nginx/html/index.html
```
我们以此Dockerfile文件,来生成了一个镜像,使用`docker build`命令。
只要
```
$ docker build .
```
会显示这样的信息:
```
Sending build context to Docker daemon 2.048 kB
Step 1/2 : FROM nginx
---> db079554b4d2
Step 2/2 : RUN echo '<h1>Hello, Docker!</h1>' > /usr/share/nginx/html/index.html
---> Running in 64127d3ff089
---> 6fb1fd56e2dd
Removing intermediate container 64127d3ff089
Successfully built 6fb1fd56e2dd
```
build成功之后可以查看一下:
```
$ docker images nginx
REPOSITORY TAG IMAGE ID CREATED SIZE
<none> <none> 6fb1fd56e2dd 4 seconds ago 182 MB
nginx v2 f51e5af097aa 44 minutes ago 182 MB
```
其中可看出,`REPOSITORY`和`TAG`部分都为none,其实我们build的时候可以给个名称标识一下。
```
$ docker build -t nginx:v3 .
```
现在就有了。
```
$ docker images nginx
REPOSITORY TAG IMAGE ID CREATED SIZE
nginx v3 6fb1fd56e2dd 4 minutes ago 182 MB
nginx v2 f51e5af097aa 48 minutes ago 182 MB
```
#### 3. 参数解释
回到之前的Dockerfile文件的内容。
```
FROM nginx
RUN echo '<h1>Hello, Docker!</h1>' > /usr/share/nginx/html/index.html
```
只有两个指令,分别是`FROM`和`RUN`。
`FROM`代表的是基础镜像,`RUN`表示的是运行的命令。
值得注意的是,每条指令都会创建一层镜像,不要单独写太多的`RUN`语句,而是要串起来。
例如,类似下面的作法是不对的。
```
FROM ruby:2.2.2
# update
RUN apt-get update -qq
# RUN apt-get upgrade -qq
# RUN apt-get dist-upgrade -qq
# RUN apt-get autoremove -qq
# for build essential lib
RUN apt-get install -y build-essential
# for postgres
RUN apt-get install -y libpq-dev
# for nokogiri
RUN apt-get install -y libxml2-dev libxslt1-dev
# for a JS runtime
RUN apt-get install -y nodejs
# for imagemagick
RUN apt-get install -y imagemagick
# for vim
RUN apt-get install -y vim
# set gem sources
RUN gem sources -r https://rubygems.org/
RUN gem sources -a https://ruby.taobao.org/
ENV APP_HOME /var/www/coomo_store
RUN mkdir -p $APP_HOME
WORKDIR $APP_HOME
ADD Gemfile* $APP_HOME/
RUN bundle install --jobs=4
ADD . $APP_HOME
```
还有很多命令,会被经常用到,比如`ARG`, `ENV`, `EXPOSE`, `WORKDIR`, `CMD`。
下面来介绍一下。
`ARG`表示的是设置一个参数,在build的时候由外面通过命令行参数的形式传过来。
比如:
```
$ docker build --build-arg PORT=3000 --build-arg NPM_TOKEN=e43d3f2c-e7b7-4522-bf74-b7d2863eddf7 .
```
传了两个参数分别为`PORT`和`NPM_TOKEN`。
`ENV`是设置环境变量,以后这个变量可以传到docker容器内部中去。
`EXPOSE`表示暴露的端口号。
`WORKDIR`就是指定工作目录啦。
`CMD`是容器启动的命令。
来看一个实例,具体体会一下这些命令。
```
from node:6.9
ARG PORT
ARG NPM_TOKEN
ENV PORT ${PORT}
ENV NPM_TOKEN ${NPM_TOKEN}
EXPOSE ${PORT}
ADD . /code
WORKDIR /code
RUN npm install
RUN npm run build
CMD npm run docker
```
下面这个链接是官方给的关于Dockerfile的文档:
<https://docs.docker.com/engine/reference/builder/#dockerfile-examples>
完结。
下一篇:[docker的数据卷(六)](https://www.rails365.net/articles/docker-de-shu-ju-juan-liu)
- 0. 介绍
- 1. 安装 docker
- 2. docker 的镜像和镜像源加速
- 3. docker 的容器
- 4. 理解 docker 镜像的层叠结构
- 5. 使用 Dockerfile 文件
- 6. docker 的数据卷
- 7. Docker Compose 的介绍与安装
- 8. 使用 compose 部署 GitLab 应用
- 9. 使用 compose 部署 Rocket.Chat 应用
- 10. docker 部署深入理解
- 11. 部署 owncloud 与 phpMyAdmin
- 12. 让 php-fpm 跑的 owncloud 应用 docker 化
- 13. docker 迁移 GitLab 项目