2022-08-03 23:31:38 +08:00
|
|
|
|
[#]: subject: "How To Build Custom Docker Image Using Dockerfile"
|
|
|
|
|
[#]: via: "https://ostechnix.com/a-brief-introduction-to-dockerfile/"
|
|
|
|
|
[#]: author: "sk https://ostechnix.com/author/sk/"
|
|
|
|
|
[#]: collector: "lkxed"
|
2022-08-04 17:21:03 +08:00
|
|
|
|
[#]: translator: "Donkey-Hao"
|
|
|
|
|
[#]: reviewer: "wxy"
|
|
|
|
|
[#]: publisher: "wxy"
|
|
|
|
|
[#]: url: "https://linux.cn/article-14896-1.html"
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
如何使用 Dockerfile 创建自定义 Docker 镜像
|
|
|
|
|
======
|
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
![](https://img.linux.net.cn/data/attachment/album/202208/04/172001acb136363vi6vcgk.jpg)
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
在这份指南中,我们将看到 **Dockerfile** 的简要介绍以及如何在 Linux 中使用 Dockerfile 来自动的 **创建自定义 Docker 镜像** 。
|
|
|
|
|
|
|
|
|
|
### 什么是 Dockerfile ?
|
|
|
|
|
|
|
|
|
|
Dockerfile 是附有构建 Docker 镜像说明的易于理解的文本文件。它囊括了用户在创建镜像时可以调用的所有命令。
|
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
我们可以使用 Dockerfile 创建自定义的镜像。可以通过 Docker Hub 分享的自定义 Docker 镜像。
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
如果你还不知道,Docker Hub 是 Docker 提供的托管存储库服务,用于团队查找和共享容器镜像,当然世界上任何人也都可以访问。
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
想象一下,早期如果我们想用 **Nginx**,我们要通过很多步骤,才能安装和配置好 Nginx 。得益于 Docker Hub ,现在我们可以在几分钟内,下载并运行 Nginx 的预置容器镜像。
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
![Nginx Docker Image In Dockerhub][1]
|
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
运行如下命令从 Docker Hub 上拉取 Nginx 镜像:
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
# docker pull nginx
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
一旦我们拉取了 Docker 镜像,可以运行如下命令使用它:
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
# docker run -it -d -p 8080:8080 nginx
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
就这样,十分简单!
|
|
|
|
|
|
|
|
|
|
参考下方链接,了解更多使用 Docker 的方式:
|
|
|
|
|
|
|
|
|
|
* [开始使用 Docker][2]
|
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
Docker Hub 上有超过十万个来自软件供应商、开源项目以及社区的容器镜像。
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
你可以从 Docker Hub 上下载你选择的镜像,并且使用上面的命令开始使用它。
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
### 理解 Dockerfile 格式
|
|
|
|
|
|
|
|
|
|
Docker 可以读取 Dockerfile 中的 **指令** 来自动的创建镜像。
|
|
|
|
|
|
|
|
|
|
典型的 Dockerfile 包含如下指令:
|
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
1、`FROM` —— 这会设置容器的基础镜像。
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
例如:
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
FROM ubuntu:22.04
|
|
|
|
|
```
|
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
这会将容器的基础镜像设置为 Ubuntu 。如果 ‘22.04’ 这个标志没有特别指明,则会设为最新版本(`latest`)。
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
2、`LABEL` —— 这是用来明确镜像的元数据信息的键值对。
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
例如:
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
LABEL ENV=“DEVELOPMENT”
|
|
|
|
|
```
|
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
3、`RUN` —— 这会在基础镜像中执行指令并创建一个新层。
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
例如:
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
RUN apt-get update
|
|
|
|
|
RUN apt-get install tomcat
|
|
|
|
|
```
|
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
4、`CMD` —— 这用来设置容器启动后先执行的命令。
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
例如:
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
```
|
2022-08-04 17:21:03 +08:00
|
|
|
|
CMD ["java", "-jar", "app.jar"]
|
2022-08-03 23:31:38 +08:00
|
|
|
|
```
|
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
5、`EXPOSE` —— 设置用于访问容器的端口。容器将会监听该端口。我们可以用来获得输出。
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
例如:
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
EXPOSE 8080
|
|
|
|
|
```
|
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
6、``MAINTAINER` —— 显示创建镜像作者的信息。
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
例如:
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
MAINTAINER info@ostechnix.com
|
|
|
|
|
```
|
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
7、`ENV` —— 用来设置环境变量的键值对。这些变量在镜像创建的时候设置,并在容器创建好后可以使用。
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
例如:
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
ENV DB_NAME=”MySQL”
|
|
|
|
|
ENV DB_VERSION=”8.0”
|
|
|
|
|
```
|
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
8、`COPY` —— 用来拷贝本地文件至容器中。
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
例如:
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
COPY /target/devops.jar devops.jar
|
|
|
|
|
```
|
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
9、`ADD` —— 具有与拷贝相同的功能,不过更进一步还可以提取本地的 tar 文件或者从 URL 拷贝文件。
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
例如:
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
ADD devops.tar.xz / .
|
|
|
|
|
ADD http://example.com/abc.git /usr/local/devops/
|
|
|
|
|
```
|
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
10、`ENTRYPOINT` —— 用来设置镜像的主要命令。与 CMD 指令功能相同。不同的是 `ENTRYPOINT` 中的指令不会被重写。
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
例如:
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
```
|
2022-08-04 17:21:03 +08:00
|
|
|
|
ENTRYPOINT ["java", "-jar", "app.jar"]
|
2022-08-03 23:31:38 +08:00
|
|
|
|
```
|
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
11、`VOLUME` —— 该指令用来创建指定位置的挂载点。
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
例如:
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
VOLUME /app/devops
|
|
|
|
|
```
|
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
12、`USER` —— 将设置运行镜像并使用的用户名称以及用户组。
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
例如:
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
USER dhruv
|
|
|
|
|
USER admin
|
|
|
|
|
```
|
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
13、`WORKDIR` —— 这会设置工作目录。如果目录不存在,则会创建。
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
例如:
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
WORKDIR /var/lib/
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
这是一个 Dockerfile 的样本,可以参考一下:
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
FROM ubuntu:latest
|
|
|
|
|
MAINTAINER Senthilkumar Palani "info@ostechnix.com"
|
|
|
|
|
RUN apt-get install -y software-properties-common python
|
|
|
|
|
RUN add-apt-repository ppa:chris-lea/node.js
|
|
|
|
|
RUN echo "deb http://us.archive.ubuntu.com/ubuntu/ jammy universe" >>
|
|
|
|
|
/etc/apt/sources.list
|
|
|
|
|
RUN apt-get update
|
|
|
|
|
RUN apt-get install -y nodejs
|
|
|
|
|
RUN mkdir /var/www
|
|
|
|
|
ADD app.js /var/www/app.js
|
|
|
|
|
CMD ["/usr/bin/node", "/var/www/app.js"]
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
我将向你展示创建一个 Dockerfile 、创建并使用镜像的简单例子。
|
|
|
|
|
|
|
|
|
|
### 创建一个 Dockerfile
|
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
创建一个名为 `dockerfile` 的文件:
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
# nano dockerfile
|
|
|
|
|
```
|
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
添加下面几行命令。我们将更新并安装 `vim` 和 `curl` 包:
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
FROM alpine
|
|
|
|
|
|
|
|
|
|
RUN apk update
|
|
|
|
|
RUN apk add vim
|
|
|
|
|
RUN apk add curl
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
![Dockerfile For Alpine Linux][3]
|
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
按下 `CTRL+O` 和 `CTRL+X` 键保存文件并关闭。
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
现在 Dockerfile 已经就位。让我们继续,用该 Dockerfile 创建一个镜像。
|
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
> **注意:** 如果你在使用 [Docker 桌面版][4],你可以以一个普通用户运行 `docker` 命令。
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
### 使用 Dockerfile 创建 Docker 镜像
|
|
|
|
|
|
|
|
|
|
只需运行以下命令,便可以使用 Dockerfile 创建 Docker 镜像:
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
# docker build -t alpine .
|
|
|
|
|
```
|
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
请注意最后有一个 **点**(`.`)。
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
输出示例:
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
[+] Building 51.2s (8/8) FINISHED
|
|
|
|
|
=> [internal] load build definition from Dockerfile 0.1s
|
|
|
|
|
=> => transferring dockerfile: 104B 0.0s
|
|
|
|
|
=> [internal] load .dockerignore 0.1s
|
|
|
|
|
=> => transferring context: 2B 0.0s
|
|
|
|
|
=> [internal] load metadata for docker.io/library/alpine:latest 38.8s
|
|
|
|
|
=> [1/4] FROM docker.io/library/alpine@sha256:7580ece7963bfa863801466c0a 2.7s
|
|
|
|
|
=> => resolve docker.io/library/alpine@sha256:7580ece7963bfa863801466c0a 0.0s
|
|
|
|
|
=> => sha256:d7d3d98c851ff3a95dbcb70ce09d186c9aaf7e25d48 1.47kB / 1.47kB 0.0s
|
|
|
|
|
=> => sha256:530afca65e2ea04227630ae746e0c85b2bd1a179379 2.80MB / 2.80MB 2.4s
|
|
|
|
|
=> => sha256:7580ece7963bfa863801466c0a488f11c86f85d9988 1.64kB / 1.64kB 0.0s
|
|
|
|
|
=> => sha256:9b2a28eb47540823042a2ba401386845089bb7b62a9637d 528B / 528B 0.0s
|
|
|
|
|
=> => extracting sha256:530afca65e2ea04227630ae746e0c85b2bd1a179379cbf2b 0.2s
|
|
|
|
|
=> [2/4] RUN apk update 4.3s
|
|
|
|
|
=> [3/4] RUN apk add vim 3.5s
|
|
|
|
|
=> [4/4] RUN apk add curl 1.3s
|
|
|
|
|
=> exporting to image 0.4s
|
|
|
|
|
=> => exporting layers 0.4s
|
|
|
|
|
=> => writing image sha256:14231deceb6e8e6105d2e551799ff174c184e8d9be8af 0.0s
|
|
|
|
|
=> => naming to docker.io/library/alpine 0.0s
|
|
|
|
|
|
|
|
|
|
Use 'docker scan' to run Snyk tests against images to find vulnerabilities and learn how to fix them
|
|
|
|
|
```
|
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
按照上面的命令, Docker 会通过保存在当前工作目录中的 Dockerfile 中的命令开始自动的创建镜像。还记得我们在 Dockerfile 中保存的 `apk update`、`apk add vim` 和 `apk add curl` 命令吗?这些命令也将会自动的执行。
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
如果 Dockerfile 保存在其他目录,你可以使用 `-f` 标志来指定路径,例如:
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
# docker build -f /path/to/a/Dockerfile .
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
创建好镜像后,我们可以使用如下命令运行它:
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
# docker run -it alpine
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
该命令会启动这个 Alpine 容器并连接到它。
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
/ # uname -a
|
|
|
|
|
Linux 8890fec82de8 5.10.104-linuxkit #1 SMP Thu Mar 17 17:08:06 UTC 2022 x86_64 Linux
|
|
|
|
|
/ # cat /etc/alpine-release
|
|
|
|
|
3.16.1
|
|
|
|
|
/ #
|
|
|
|
|
```
|
|
|
|
|
|
2022-08-04 17:21:03 +08:00
|
|
|
|
如果你使用 Docker 桌面版,你可以通过<ruby>容器<rt>Containers</rt></ruby>标签页界面来查看运行中的容器。
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
![View Containers In Docker Desktop][5]
|
|
|
|
|
|
|
|
|
|
这就是使用 Dockerfile 构建自定义容器映像的方式。
|
|
|
|
|
|
|
|
|
|
我们仅仅讲了基础内容。你可以用 Dockerfile 做到很多东西。建议你参考一下官方 [Dockerfile 参考][6] ,以了解更多内容。
|
|
|
|
|
|
|
|
|
|
--------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
via: https://ostechnix.com/a-brief-introduction-to-dockerfile/
|
|
|
|
|
|
|
|
|
|
作者:[sk][a]
|
|
|
|
|
选题:[lkxed][b]
|
|
|
|
|
译者:[Donkey](https://github.com/Donkey-Hao)
|
2022-08-04 17:21:03 +08:00
|
|
|
|
校对:[wxy](https://github.com/wxy)
|
2022-08-03 23:31:38 +08:00
|
|
|
|
|
|
|
|
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
|
|
|
|
|
|
|
|
|
|
[a]: https://ostechnix.com/author/sk/
|
|
|
|
|
[b]: https://github.com/lkxed
|
|
|
|
|
[1]: https://ostechnix.com/wp-content/uploads/2022/07/Nginx-Docker-Image-In-Dockerhub.png
|
|
|
|
|
[2]: https://ostechnix.com/getting-started-with-docker/
|
|
|
|
|
[3]: https://ostechnix.com/wp-content/uploads/2022/07/Dockerfile-For-Alpine-Linux.png
|
|
|
|
|
[4]: https://ostechnix.com/docker-desktop-for-linux/
|
|
|
|
|
[5]: https://ostechnix.com/wp-content/uploads/2022/07/View-Containers-In-Docker-Desktop-1024x524.png
|
|
|
|
|
[6]: https://docs.docker.com/engine/reference/builder/
|