Dockerfile详解

结构

DockerFile分为四部分组成:基础镜像信、维护者信息、镜像操作指令和容器启动时执行指令。例如:

#第一行必须指令基于的基础镜像
From ubutu

#维护者信息
MAINTAINER docker_user  docker_user@mail.com

#镜像的操作指令
apt/sourcelist.list

RUN apt-get update && apt-get install -y ngnix 
RUN echo "\ndaemon off;">>/etc/ngnix/nignix.conf

#容器启动时执行指令
CMD /usr/sbin/ngnix
指令
From指令

DockerFile第一条必须为From指令。如果同一个DockerFile创建多个镜像时,可使用多个From指令(每个镜像一次)

MAINTAINER指令

格式为maintainer ,指定维护者的信息

RUN

格式为Run 或者Run [“executable” ,”Param1”, “param2”] 前者在shell终端上运行,即/bin/sh -C,后者使用exec运行。例如:RUN [“/bin/bash”, “-c”,”echo hello”] 每条run指令在当前基础镜像执行,并且提交新镜像。当命令比较长时,可以使用“/”换行
例如:

Dockerfile 时区设置
RUN ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
RUN echo 'Asia/Shanghai' >/etc/timezone
CMD指令

支持三种格式(每个容器只能执行一条CMD命令,多个CMD命令时,只最后一条被执行。):

CMD [“executable” ,”Param1”, “param2”]使用exec执行,推荐 
CMD command param1 param2,在/bin/sh上执行 
CMD [“Param1”, “param2”] 提供给ENTRYPOINT做默认参数。
EXPOSE

格式为 EXPOSE […]

告诉Docker服务端容器暴露的端口号,供互联系统使用。在启动Docker时,可以通过-P,主机会自动分配一个端口号转发到指定的端口。使用-P,则可以具体指定哪个本地端口映射过来
例如: 
EXPOSE 22 80 8443
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

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

COPY

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

ENTRYPOINT
两种格式:
ENTRYPOINT [“executable”, “param1”, “param2”] 
ENTRYPOINT command param1 param2 (shell中执行)

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

VOLUME

格式为 VOLUME [“/data”]
创建一个可以从本地主机或其他容器挂载的挂载点,一般用来存放数据库和需要保持的数据等。

USER

格式为 USER daemon
指定运行容器时的用户名或UID,后续的 RUN 也会使用指定用户。当服务不需要管理员权限时,可以通过该命令指定运行用户。并且可以在之前创建所需要的用户,例如: RUN groupadd -r postgres && useradd -r -g postgres 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 
[…] 
  • 如果基于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
创建镜像

通过Docker Build 创建镜像。 命令读取指定路径下(包括子目录)所有的Dockefile,并且把目录下所有内容发送到服务端,由服务端创建镜像。另外可以通过创建.dockerignore文件(每一行添加一个匹配模式)让docker忽略指定目录或者文件
格式为Docker Build [选项] 路径 需要制定标签信息,可以使用-t选项 例如:Dockerfile路径为 /tmp/docker_build/,生成镜像的标签为build_repo/my_images

$dudo docker build -t build_repo/my_images /tmp/docker_build/
DockerfileDocker镜像构建的脚本文件,通过Dockerfile文件可以定义镜像的构建过程,包括基础镜像、软件安装、环境变量设置、运行命令等。 Dockerfile的基本语法如下: ``` # Comment INSTRUCTION arguments ``` 其中,#后面的内容为注释,INSTRUCTION为指令,arguments为指令的参数。 常用的指令包括: - FROM:指定基础镜像 - MAINTAINER:指定镜像维护者信息 - RUN:执行命令,可以用\换行 - CMD:指定容器启动时执行的命令,可以被docker run的命令行参数覆盖 - ENTRYPOINT:指定容器启动时执行的命令,不能被docker run的命令行参数覆盖 - EXPOSE:指定容器中的应用监听的端口 - ENV:设置环境变量 - ADD:将本地文件或目录复制到容器中 - COPY:将本地文件或目录复制到容器中,与ADD不同的是,COPY只复制文件,不会自动解压缩文件 - VOLUME:指定容器中的数据卷 - USER:指定容器中的用户 - WORKDIR:指定容器中的工作目录 一个简单的Dockerfile示例: ``` # Use an official Python runtime as a parent image FROM python:2.7-slim # Set the working directory to /app WORKDIR /app # Copy the current directory contents into the container at /app COPY . /app # Install any needed packages specified in requirements.txt RUN pip install --trusted-host pypi.python.org -r requirements.txt # Make port 80 available to the world outside this container EXPOSE 80 # Define environment variable ENV NAME World # Run app.py when the container launches CMD ["python", "app.py"] ``` 以上Dockerfile的作用是: - 使用Python 2.7镜像作为基础镜像 - 设置工作目录为/app - 将当前目录下的文件复制到容器的/app目录下 - 安装requirements.txt中指定的Python依赖库 - 暴露容器的80端口 - 设置环境变量NAME为World - 启动app.py。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值