Dockerfile

文章目录

    • 基本概念
    • 文件格式
    • 指令
      • FROM
      • LABEL MAINTAINER
      • RUN
      • CMD
      • EXPOSE
      • ENV
      • ADD
      • COPY
      • ENTRYPOINT
      • VOLUME
      • USER
      • WORKDIR
      • ONBUILD
    • 创建镜像
    • 练习题

基本概念

Docker镜像是一个特殊的文件系统,除了提供容器运行时所需的程序、库、资源、配置等文件外,还包含了一些为运行时准备的一些配置参数(如匿名卷、环境变量、用户等)。

镜像的定制实际上就是定制每一层所添加的配置、文件。如果我们可以把每一层修改、安装、构建、操作的命令都写入一个脚本,用这个脚本来构建、定制镜像,那么之前提及的无法重复的问题、镜像构建透明性的问题、体积的问题就都会解决。这个脚本就是Dockerfile。

Dockerfile是一个文本文件,其内包含了一条条的指令(Instruction),每一条指令构建一层,因此每一条指令的内容,就是描述该层应当如何构建。有了Dockerfile,当我们需要定制自己额外的需求时,只需在 Dockerfile上添加或者修改指令,重新生成镜像即可

文件格式

Docker分为四部分:

  • 基础镜像信息
  • 维护者信息
  • 镜像操作指令
  • 容器启动时默认要执行的指令

其中,一开始必须指明所基于的镜像名称,接下来一般会说明维护者信息。
后面则是镜像操作指令,例如RUN指令,RUN指令将对镜像执行跟随的命令。每运行一条RUN指令,镜像添加新的一层,并提交。
最后是CMD指令来指定运行容器时的操作指令。

指令

指令包括:

  • FROM
  • LABEL MAINTAINER
  • RUN
  • CMD
  • EXPOSE
  • ENV
  • ADD
  • COPY
  • ENTRYPOINT
  • VOLUME
  • USER
  • WORKDIR
  • ONBUILD

FROM

格式为FROM ``FROM :

第一条指令必须为FROM指令。并且,如果在同一个Dockerfile中创建多个镜像时,可以使用多个FROM指令(每个镜像一次)。

LABEL MAINTAINER

格式为LABEL MAINTAINER ,指定维护者信息

RUN

格式为RUN RUN ["executable","param1","param2"]

前者将在shell终端中运行命令,即/bin/sh -c;后者则使用exec执行。指定使用其他终端可以通过第二种方式实现,例如:

RUN ["/bin/bash","-c","echo hello"]

CMD

CMD支持三种格式:

  • CMD ["executable","param1","param2"] 使用exec执行,推荐方式
  • CMD command param1 param2 在/bin/sh中执行,提供给需要交互的应用
  • CMD ["param1","param2"] 提供给ENTRYPOINT的默认参数

CMD用于指定启动容器时默认要执行的命令,每个Dockerfile只能有一条CMD命令。如果指定了多条命令,只有最后一条会被执行。

如果用户启动容器时指定了运行的命令,则会覆盖掉CMD指定的命令。

EXPOSE

格式为EXPOSE [...]
例如:

EXPOSE 22 80 8443

EXPOSE用于告诉Docker服务器容器暴露的端口号,供互联系统使用。

在启动容器时通过-P,Docker主机会自动分配一个端口转发到指定的端口;
使用-p则可以具体指定哪个本地端口映射过来。

ENV

格式为ENV 。指定一个环境变量,会被后续RUN指令使用,并在容器运行时保持。例如:

ENV PG_MAJOR 9.3
ENV PG_VERSION 9.3.4
RUN curl -SL http://example.com/postgres-$PG_VERSION.tar.xz | tar -xJC /usr/src/postgress && ...
ENV PATH /usr/local/postgres-$PG_MAJOR/bin:$PATH

ADD

格式为ADD

该命令将复制指定的到容器中的。其中可以是Dockerfile所在目录的一个相对路径(文件或目录);也可以是一个URL;还可以是一个tar文件(会自动解压为目录)。

COPY

格式为COPY

复制本地主机的(为Dockerfile所在目录的相对路径,文件或目录)为容器中的。目标路径不存在时会自动创建。

当使用本地目录为源目录时,推荐使用COPY。

ENTRYPOINT

ENTRYPOINT有两种格式:

  • ENTRYPOINT ["executable","param1","param2"]
  • ENTRYPOINT command param1 param2(在shell中执行)

配置容器启动后执行的命令,并且不可被docker run提供的参数覆盖。而且,如果在docker run的后面提供了参数,这些命令行参数会被当作参数传递给ENTRYPOINT指定的程序。

每个Dockerfile中只能有一个ENTRYPOINT,当指定多个ENTRYPOINT时,只有最后一个生效。

VOLUME

格式为VOLUME ["/data"]

创建一个可以从本地主机或其他容器挂载的挂载点,一般用来存放数据库和需要保持的数据等。

USER

格式为USER daemon

指定运行容器时的用户名或UID,后续的RUN也会使用指定用户。

当服务不需要管理员权限时,可以通过该命令指定运行用户。并且可以在之前创建所需要的用户

WORKDIR

格式为WORKDIR /path/to/workdir

为后续的RUN、CMD、ENTRYPOINT指令配置工作目录。
可以使用多个WORKDIR指令,后续命令如果参数是相对路径,则会基于之前命令指定的路径。

ONBUILD

格式为ONBUILD [INSTRUCTION]

配置当所创建的镜像作为其他镜像的基础镜像时,所执行的操作指令。

例如,Dockerfile使用如下的内容创建了镜像image-A

[...]
ONBUILD ADD . /app/src
ONBUILD RUN /usr/local/bin/python-build --dir /app/src
[...]

此时,如果基于image-A创建新的镜像时,新的Dockerfile中使用FROM image-A指定基础镜像时,会自动执行ONBUILD指令的内容,等价于在后面添加了两条指令。

FROM image-A

ADD . /app/src
RUN /usr/local/bin/python-build --dir /app/src

使用ONBUILD指令的镜像,推荐在标签中注明

创建镜像

编写完成Dockerfile后,可以通过docker build命令来创建镜像。

基本的格式为docker build [选项] 路径,该命令将读取指定路径下(包括子目录)的Dockerfile,并将该路径下所有内容发送给Docker服务端,由服务端来创建镜像。因此一般建议放置Dockerfile的目录为空目录。

另外,可以通过 .dockerignore 文件(每一行添加一条匹配模式)来让Docker忽略路径下的目录和文件。

要指定镜像的标签信息,可以通过-t选项。

练习题

1、基于基础镜像centos:7

[root@100 ~]# vim Dockerfile
FROM centos:7

2、维护者信息

MAINTAINER Frices

3、添加Centos-7仓库

ADD Centos-7.repo /etc/yum.repos.d/

4、添加epel-7仓库

ADD epel-7.repo /etc/yum.repos.d/

5、安装nginx软件包

RUN yum -y install nginx

6、暴露指定端口80

EXPOSE 80

7、构建镜像,镜像名称为nginx:v1

CMD:[“/usr/sbin/nginx”,”-g”,”daemon off;”]
[root@100 ~]# docker build -t nginx:v1 .
[root@100 ~]# docker images
REPOSITORY   TAG       IMAGE ID       CREATED              SIZE
nginx        v1        3f21a8cec898   About a minute ago   459MB

8、运行容器,容器名称为自己名字的全拼,映射端口88:80

[root@100 ~]# docker run -d --name liyan -p 88:80 nginx:v1
46bbe23a503992b5a97519829b4d077c0a24ca5d4c06fb2a88c456c4f8325c6c
[root@100 ~]# docker ps
CONTAINER ID   IMAGE      COMMAND                  CREATED         STATUS        PORTS                               NAMES
46bbe23a5039   nginx:v1   "/usr/sbin/nginx -g …"   2 seconds ago   Up 1 second   0.0.0.0:88->80/tcp, :::88->80/tcp   liyan

9、进入容器,删除默认网页,写入新的默认网页,网页内容为你们自己名字的全拼

[root@100 ~]# docker exec -it liyan /bin/bash
[root@46bbe23a5039 /]# cd /usr/share/nginx/
[root@46bbe23a5039 nginx]# cd html/
[root@46bbe23a5039 html]# ls
404.html  50x.html  en-US  icons  img  index.html  nginx-logo.png  poweredby.png
[root@46bbe23a5039 html]# rm -rf index.html
[root@46bbe23a5039 html]# echo "Liyan" > index.html
[root@46bbe23a5039 html]# ls
404.html  50x.html  en-US  icons  img  index.html  nginx-logo.png  poweredby.png

10、通过浏览器,能够正常访问nginx
Dockerfile_第1张图片

你可能感兴趣的:(docker,linux,运维)