Dockerfile基本结构是什么

87次阅读
没有评论

共计 4081 个字符,预计需要花费 11 分钟才能阅读完成。

这篇文章主要讲解了“Dockerfile 基本结构是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着丸趣 TV 小编的思路慢慢深入,一起来研究和学习“Dockerfile 基本结构是什么”吧!

## 基本结构

Oockerfile 由一行行语句行组成,支持以__#__开头的注释行。

通常一个 Dockerfile 文件包含四个组成部分:基础镜像信息、维护者信息、镜像操作指令和容器启动时执行的命令。

比如,下面这个简单的示例:

#  镜像基础信息
# This dockerfile uses the ubuntu image
# VERSION 2 - EDITION 1
# Author: docker_user
# Command format: Instruction [arguments / command] ..
# Base image to use, this must be set as the first line
FROM ubuntu
#维护者信息
# Maintainer: docker_user  docker_user at email.com  (@docker_user)
MAINTAINER docker_user docker_user@email.com
#镜像操作指令
# Commands to update the image
RUN echo  deb http://archive.ubuntu.com/ubuntu/ raring main universe    /etc/apt/sources.list
RUN apt-get update   apt-get install -y nginx
RUN echo  \ndaemon off;    /etc/nginx/nginx.conf
#  容器启动时执行
# Commands when creating a new container
CMD /usr/sbin/nginx

每个 Dockerifle 文件必须首先指明基础镜像信息,接下来推荐说明维护者信息,维护者信息不是必须的。

## 指令

### 注释:

使用 # 来注释

示例:

# Memcached
# VERSION 1.0
# use the ubuntu base image provided by dotCloud
FROM ubuntu
# make sure the package repository is up to date
RUN echo  deb http://archive.ubuntu.com/ubuntu precise main universe    /etc/apt/sources.list
RUN apt-get update
# install memcached
RUN apt-get install -y memcached

###FROM:

FROM  image

或者

FROM  image: tag 

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

示例:

FROM ubuntu

如果指定的镜像本地没有,Dokcer 会自动从仓库注册服务器下载指定的镜像;如果没有指定__tag__,则默认 tag 是__latest__,如果都没有则会报错。

###MAINTAINER:

MAINTAINER  name

该指令用于指定维护者信息。比如姓名,联系方式等。

示例:

MAINTAINER Anoxia windorman@gmaillcom

###RUN:

RUN  command  (the command is run in a shell - `/bin/sh -c`)

或者

RUN [executable ,  param1 ,  param2  ...] (exec form)

RUN 命令等价于:

docker run image command
docker commit container_id

示例:

RUN apt-get update
RUN apt-get -y install apache2

###CMD:

CMD [executable , param1 , param2]

使用 exec 执行,推荐方式;

或者

CMD command param1 param2

在 /bin/sh 中执行,提供给需要交互的应用;

或者

CMD [param1 , param2]

提供给 ENTRYPOINT 的默认参数;

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

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

示例:

CMD [/usr/sbin/apachectl ,  -D ,  FOREGROUND]

###EXPOSE:

EXPOSE  port  [port ...]

告诉 Docker 服务端容器暴露的端口号,共互联系统使用。在启动容器时需要通过 -P,Docker 主机会自动分配一个端口转发到指定的端口。

示例:

EXPOSE 11211

###ENV:

ENV  key   value

指定一个环境变量,会被后续 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

使用此 ENV 生成的 image 新建 container,可以通过 docker inspect 看到这个环境变量:

root@tankywoo-docker:~# docker inspect 49bfc7a9817f
 Env : [
  name=tanky ,
  HOME=/ ,
  PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin 
...

里面的 name=tanky 就是设置的。也可以通过在 docker run 时设置或修改环境变量:

docker run -i -t --env name= tanky  ubuntu:newtest /bin/bash

###ADD:

ADD  src   dest

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

示例:

ADD ./scripts/start.sh /start.sh

###COPY:

COPY  src   dest

复制本地主机的 src(为 Dockerfile 所在目录的相对路径)到容器中的 dest。当使用本地目录为源目录时,推荐使用 COPY。

示例:

ADD ./scripts/start.sh /start.sh

###ENTRYPOINT:

ENTRYPOINT [executable ,  param1 ,  param2]

或者:

ENTRYPOINT command param1 param2(shell 中执行)

配置容器启动后执行的命令,并且不可被 docker run 提供的参数覆盖。每个 Dockerfile 中只能有一个 ENTRYPOINT,当指定多个时,只有最后一个起效。

示例:

ENTRYPOINT [echo ,  Whale you be my container]

###VOLUME:

VOLUME [mountpoint]

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

示例:

VOLUME [/data]

###USER:

USER daemon

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

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

RUN groupadd -r postgres   useradd -r -g postgres postgres
USER postgres

要临时获取管理员权限可以使用 gosu,而不推荐 sudo。

###WORKDIR

WORKDIR /path/to/workdir

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

示例:

WORKDIR /a
WORKDIR b
WORKDIR c
RUN pwd

则最终路径为 /a/b/c。

###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
#Automatically run the following
ADD . /app/src
RUN /usr/local/bin/python-build --dir /app/src

使用 ONBUILD 指令的镜像,推荐在标签中注明,例如 ruby:1.9-onbuild。

感谢各位的阅读,以上就是“Dockerfile 基本结构是什么”的内容了,经过本文的学习后,相信大家对 Dockerfile 基本结构是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是丸趣 TV,丸趣 TV 小编将为大家推送更多相关知识点的文章,欢迎关注!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-08-16发表,共计4081字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)