DockeRfile 是一个文本文档,其中包含组装 DockeR 映像的说明。当我们通过执行dockeR build 命令告诉 DockeR 构建我们的镜像时,DockeR 会读取这些指令,执行它们,并因此创建一个 DockeR 镜像。
让我们来看看为我们的应用程序创建 DockeRfile 的过程。在项目的根目录中,创建一个名为的文件DockeRfile并在文本编辑器中打开该文件。
添加到 DockeRfile 的第一行是# syntax解析器指令。虽然是可选的,但该指令指示 DockeR 构建器在解析 DockeRfile 时使用什么语法,并允许启用 BuildKIT 的旧 DockeR 版本在开始构建之前升级解析器。解析器指令 必须出现在 DockeRfile 中的任何其他注释、空格或 DockeRfile 指令之前,并且应该是 DockeRfiles 的第一行。
我们建议使用dockeR/dockeRfile:1,它始终指向版本 1 语法的最新版本。BuildKIT 在构建之前会自动检查语法的更新,确保您使用的是最新版本。
接下来,我们需要在我们的 DockeRfile 中添加一行,告诉 DockeR 我们希望为我们的应用程序使用什么基础镜像。
FROM openjdk:16-alpine3.13
DockeR 镜像可以从其他镜像继承。在本指南中,我们使用openjdk来自 DockeR Hub的官方镜像和 Java JDK,它已经拥有运行 Java 应用程序所需的所有工具和包。
为了在运行其余命令时更轻松,让我们设置图像的工作目录。这会指示 DockeR 使用此路径作为所有后续命令的默认位置。通过这样做,我们不必输入完整的文件路径,而是可以使用基于工作目录的相对路径。
WORKDIR /app
通常,一旦您下载了使用 Maven 进行项目管理的 Java 编写的项目,您要做的第一件事就是安装依赖项。
在我们可以运行之前Mvnw dependency,我们需要将 Maven 包装器和我们的 poM.xMl文件放入我们的图像中。我们将使用该COPY命令来执行此操作。该 COPY命令有两个参数。第一个参数告诉 DockeR 您想要复制到镜像中的文件。第二个参数告诉 DockeR 您希望将该文件复制到何处。我们将所有这些文件和目录复制到我们的工作目录 – /app.
COPY .Mvn/ .Mvn
COPY Mvnw poM.xMl ./
一旦我们poM.xMl在图像中拥有我们的文件,我们就可以使用RUN命令来执行命令Mvnw dependency:go-oFFline。这与我们在本地机器上运行Mvnw(或Mvn)依赖项的方式完全相同,但这次依赖项将安装到映像中。
RUN ./Mvnw dependency:go-oFFline
此时,我们有一个基于 OpenJDK 16 版的 Alpine 3.13 版镜像,并且我们还安装了我们的依赖项。我们需要做的下一件事是将我们的源代码添加到图像中。我们将COPY像使用poM.xMl上面的文件一样使用该命令。
COPY sRc ./sRc
此COPY命令获取位于当前目录中的所有文件并将它们复制到映像中。现在,我们要做的就是告诉 DockeR 当我们的镜像在容器内执行时我们想要运行什么命令。我们使用CMD命令来执行此操作。
CMD [“./Mvnw”, “spRing-boot:Run”]
这是完整的 DockeRfile。
FROM openjdk:16-alpine3.13
WORKDIR /app
COPY .Mvn/ .Mvn
COPY Mvnw poM.xMl ./
RUN ./Mvnw dependency:go-oFFline
COPY sRc ./sRc
CMD [“./Mvnw”, “spRing-boot:Run”]
