Dockerfile

返回目录

Dockerfile

# 指定基础镜像
FROM <image>
FROM <image>:<tag>
FROM <image>@<digest>
# 维护者名
MAINTAINER <name>
# RUN指令创建的中间镜像会被缓存,并会在下次构建中使用。如果不想使用这些缓存镜像,可以在构建时指定–no-cache参数,如docker build --no-cache
# 构建镜像时执行的指令 —— shell方式
RUN <command>
# 构建镜像时执行的指令 —— exec方式
RUN ["executable", "param1", "param2"]
# 将本地文件添加到容器中,tar类型文件会自动解压(网络压缩资源不会被解压),可以访问网络资源,类似wget【COPY的功能类似ADD,但是是不会自动解压文件,也不能访问网络资源】
ADD <src>... <dest>
# 若包含空格,则
ADD ["<src>",... "<dest>"]
# 构建容器后调用,也就是在容器启动时才进行调用 —— 执行可执行文件,优先
CMD ["executable","param1","param2"]
# 构建容器后调用,也就是在容器启动时才进行调用 —— 设置了ENTRYPOINT,则直接调用ENTRYPOINT添加参数
CMD ["param1","param2"]
# 构建容器后调用,也就是在容器启动时才进行调用 —— 执行shell内部命令
CMD command param1 param2
# 配置容器,使其可执行化 —— 可执行文件, 优先
ENTRYPOINT ["executable", "param1", "param2"]
# 配置容器,使其可执行化 —— shell内部命令
ENTRYPOINT command param1 param2
# 为镜像添加元数据
LABEL <key>=<value> <key>=<value> <key>=<value> ...
# 设置环境变量 —— 一次一变量,后面所有都会被识别为value值
ENV <key> <value> 
# 设置环境变量 —— 一次多变量,后面有空格则用 \ 转义,或用引号"括起来
ENV <key>=<value> ... 
# 指定于外界交互的端口
EXPOSE <port> [<port>...]
# 指定持久化目录
VOLUME ["/path/to/dir1", "/path/to/dir2"]
# 指定工作目录,类似于cd命令,设置工作目录后,Dockerfile中其后的命令RUN、CMD、ENTRYPOINT、ADD、COPY等命令都会在该目录下执行
WORKDIR /path/to/workdir
# 指定传递给构建运行时的变量
ARG <name>[=<default value>]
# 设置镜像触发器【ONBUILD [INSTRUCTION]】(当所构建的镜像被用做其它镜像的基础镜像,该镜像中的触发器将会被触发)
ONBUILD ADD XXX
ONBUILD RUN XXX
### 创建和使用 Dockerfile #### 编写 Dockerfile Dockerfile 是一种用于定义 Docker 镜像的脚本文件,它包含了构建镜像所需的一系列指令。以下是编写 Dockerfile 的基本结构和常用指令: 1. **FROM**: 定义基础镜像,这是所有 Dockerfile 中的第一个非注释指令。 示例:`FROM ubuntu:latest` 表示基于最新的 Ubuntu 镜像创建新的镜像[^4]。 2. **ENV**: 设置环境变量。 示例:`ENV JAVA_HOME /usr/local/jdk1.8.0_71` 用来设置 `JAVA_HOME` 环境变量[^4]。 3. **ADD/COPY**: 添加或复制文件到镜像中。两者的主要区别在于 `ADD` 支持远程 URL 和自动解压功能,而 `COPY` 更加直观简单。 示例:`COPY app.jar /app/` 将本地的 `app.jar` 文件复制到容器内的 `/app/` 路径下[^3]。 4. **RUN**: 执行命令以安装软件或其他必要的操作。这些命令将在构建过程中被执行。 示例:`RUN apt-get update && apt-get install -y curl` 更新包管理器并安装 `curl` 工具[^4]。 5. **EXPOSE**: 声明容器运行时监听的端口号。这不会实际开放端口,仅作为文档用途供客户端参考。 示例:`EXPOSE 8080` 指定容器内部服务使用的端口为 8080[^4]。 6. **CMD 或 ENTRYPOINT**: 定义容器启动时默认执行的命令。注意,一个 Dockerfile 只能有一个有效的 CMD 指令,若有多个,则只有最后一条生效;ENTRYPOINT 则更常用于固定入口程序调用方式。 示例:`CMD ["java", "-jar", "/app/app.jar"]` 启动 Java 应用程序[^3]。 #### 使用 Dockerfile 构建镜像 通过 `docker build` 命令可以依据 Dockerfile 来生成自定义镜像。具体语法如下: ```bash docker build [OPTIONS] PATH | URL | - ``` 常见选项包括 `-t` 设定新镜像的名字与标签以及 `-f` 明确指出所采用的 Dockerfile 名字及其位置[^2]。例如,在当前目录存在名为 php.Dockerfile 的情况下,可通过下面这条语句建立镜像: ```bash docker build -f ./php.Dockerfile -t my-php-app:v1 . ``` #### 运行由 Dockerfile 构建出来的镜像 一旦成功构建好镜像之后,就可以利用 `docker run` 把这个静态映射变成动态实例化的过程——也就是常说的“跑起来”。其基本形式如下所示: ```bash docker run [OPTIONS] IMAGE [COMMAND] [ARG...] ``` 举个例子来说就是假如前面提到过的那个 PHP Web Server 类型的应用程序已经打包完毕成为镜像叫做 `my-php-app:v1`,那么现在想让它作为一个独立的服务进程开始运作则只需要输入类似这样的东西就可以了: ```bash docker run -d --name my-running-server -p 8080:80 my-php-app:v1 ``` 这里的关键部分解释一下,“-d”表示后台模式运行容器,“--name”赋予特定名字给这次启动的新实体以便后续识别方便,“-p”实现主机端口向容器内暴露出去的功能从而允许外部访问[^3]。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值