2

我有一个非常简单的 Dockerfile,如下所示:-

FROM my-base-image
COPY abc.properties /opt/conf/

现在我的基础镜像有一个 docker 入口点(在它的 Dockerfile 的末尾),但是你可以看到这个生成的镜像没有。这是否有效,或者我们是否需要在任何给定的 Dockerfile 中有一个 docker 入口点/CMD。此外,结果图像中 COPY 指令的执行顺序是什么。我的意思是,由于这个 Dockerfile 没有入口点,它会从基本映像执行一个,但会在 COPY 指令之后执行,或者会先执行基本映像入口点,然后在容器启动时执行此 COPY 指令只是寻找概念在码头工人。

4

2 回答 2

5

一些 Dockerfile 指令(特别是 ENTRYPOINT 和 CMD,还有 EXPOSE、LABEL 和 MAINTAINER)只是在映像中设置元数据;他们自己并没有真正做任何事情。在单个 Dockerfile 中,这将正常工作:

FROM ubuntu:18.04
WORKDIR /app
# Just remembers this in the image metadata; doesn't actually run it
CMD ["/app/main.sh"]
# ...we should actually copy the file in too
COPY main.sh /app

当你从另一个镜像构建一个 Dockerfile 时,它​​的行为几乎完全就像你运行第一个 Dockerfile 中的所有命令,然后运行第二个 Dockerfile 中的所有命令一样。由于 CMD 和 ENTRYPOINT 只是设置了元数据,所以第二个图像继承了这个元数据。

构建和运行映像是两个独立的步骤。在您显示的示例中, COPY 指令在该步骤期间发生,并且基本图像的命令直到后面的步骤docker build才生效。docker run(在 Docker Compose 中也是如此;一个常见的问题是为什么 Dockerfile 步骤无法连接到 Compose YAML 文件中声明的其他容器。)

有一个例外,它在入口点附近。如果您有一个声明 ENTRYPOINT 和 CMD 的基本映像,并且您在派生映像中重新声明了 ENTRYPOINT,它也会重置 CMD(本节的最后一段)。这通常不是一个实际问题。

于 2019-11-27T13:20:19.873 回答
0

构建映像时,Dockerfile 会按照它们的说明进行合并。构建图像并不意味着它可以运行。因此,理想情况下,您来自 Base Dockerfile 和当前 Dockerfile 的指令将被打包。由于您CMD在 Base Dockerfile 中提到了入口点,因此当您使用docker run.
因此,当您构建映像时,您的子 Dockerfile 中的 COPY 语句也将被设置。并且您的图像必须构建良好。执行您的docker builddocker run让我们知道

于 2019-11-27T07:41:05.740 回答