您的位置:首页 >Docker的Dockerfile脚本基本使用指南
发布于2026-05-31 阅读(0)
扫一扫,手机访问
Dockerfile 本质上就是一个自动化的构建脚本。它由一系列命令和参数组成,这些命令层层叠加在一个基础镜像上,最终生成一个全新的镜像。整个过程从 FROM 开始,后面跟着各种配置、安装、拷贝操作,最后输出一个可以直接拿来创建容器的成品。可以说,Dockerfile 让镜像构建变得可重复、可追溯,极大简化了部署的复杂度。
在实操之前,先快速过一遍 Dockerfile 的语法规则,搞清楚它到底长什么样。
什么是语法?简单说,就是告诉计算机“用什么指令、带什么参数”的一套约定。Dockerfile 的语法设计得非常干净、直观,甚至不需要额外文档就能猜个八九不离十——支持注释,指令自解释,结构清晰。如果语法写错了,计算机就直接报错,所以规范是第一位的。
Dockerfile 里的内容由两部分组成:注释(用 # 开头)和命令(指令+参数)。
一个最简单的例子:
# Print "Hello docker!"
RUN echo "Hello docker!"
Dockerfile 提供了十几条命令来构建镜像,下面逐一介绍最常用的那些。
FROM
或
FROM :
这条指令指定基础镜像,后续所有操作都基于它。它必须放在 Dockerfile 的第一行。比如 FROM ubuntu,如果没有指定 tag,默认会取 latest;如果连这个镜像都找不到,构建就会直接失败。
RUN # shell 格式,默认用 /bin/sh -c 执行
RUN ["executable", "param1", "param2"] # exec 格式
RUN 会在当前镜像中执行命令,并提交执行结果形成新的一层。你可以把它理解为手动执行 docker run image command 后再 docker commit 的合成操作。
用 # 开头,用于解释代码,不参与构建。例如:
# 这是注释
FROM ubuntu
# 更新源
RUN echo "deb http://archive.ubuntu.com/ubuntu precise main universe" > /etc/apt/sources.list
RUN apt-get update
MAINTAINER
用来标明维护者的姓名和联系方式,算是镜像的“作者标签”。例如:
MAINTAINER Guillaume J. Charmes, guillaume@dotcloud.com
ENTRYPOINT cmd param1 param2 # shell 格式
ENTRYPOINT ["cmd", "param1", "param2"] # exec 格式
ENTRYPOINT 配置容器启动时要执行的命令。比如:
FROM ubuntu
ENTRYPOINT echo "Welcome!"
# 启动后输出 Welcome!
USER daemon
指定运行后续命令(以及容器启动后的进程)所用的用户。通常配合 ENTRYPOINT 使用,比如让 memcached 以 daemon 用户运行:
ENTRYPOINT ["memcached"]
USER daemon
EXPOSE [...]
暴露容器内的端口,方便外部与其通信。例如 memcached 默认用 11211 端口:
EXPOSE 11211
下面是一个完整的 Memcached 镜像 Dockerfile 示例:
# Memcached
# VERSION 2.2
FROM ubuntu
MAINTAINER Victor Coisne victor.coisne@dotcloud.com
# 更新源(国内建议换成 163 或 sohu 的源,不然太慢)
RUN echo "deb http://archive.ubuntu.com/ubuntu precise main universe" > /etc/apt/sources.list
RUN apt-get update
# 安装 memcached
RUN apt-get install -y memcached
# 设置启动命令
ENTRYPOINT ["memcached"]
# 以 daemon 用户运行
USER daemon
# 暴露端口
EXPOSE 11211
实际构建的过程(以 163 源为例):
docker build -t tankywoo - < Dockerfile
# 输出会显示每一步的提交,最终生成镜像
Step 0 : FROM ubuntu
Step 1 : MAINTAINER Victor Coisne ...
...
Successfully built 666c5d65f396
ENV
设置环境变量,后续的 RUN 命令可以直接使用。生成的容器中也会保留这些变量,通过 docker inspect 可以看到:
"Env": [
"name=tanky",
"HOME=/",
"PATH=/usr/local/sbin:..."
]
也可以在 docker run 时临时覆盖:docker run -i -t --env name="tanky" ubuntu:newtest /bin/bash
ADD
将构建上下文中的文件或目录复制到容器的目标路径。src 可以是本地相对路径,也可以是远程 URL。dest 必须是容器内的绝对路径。
VOLUME [""]
创建一个挂载点,用于在容器和宿主机之间共享目录。例如 VOLUME ["/data"]。
WORKDIR /path/to/workdir
设置后续 RUN、CMD、ENTRYPOINT 的执行目录。可以多次使用,如果是相对路径,则基于上一个 WORKDIR。比如:
WORKDIR /a
WORKDIR b
WORKDIR c
RUN pwd
# 实际在 /a/b/c 下执行 pwd
CMD ["executable","param1","param2"] # exec 格式
CMD ["param1","param2"] # 作为 ENTRYPOINT 的默认参数
CMD command param1 param2 # shell 格式
CMD 提供容器启动时的默认命令。一个 Dockerfile 里只能有一个 CMD,如果有多个,只有最后一个会生效。
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
4
5
6
7
8
9