如评论中所述,多阶段构建涉及单个Dockerfile来执行多个阶段。您拥有的是一个通用的基本映像。
您可以使用以下语法将它们转换为非传统的多阶段构建(我说是非传统的,因为您不执行各层之间的任何复制,而是仅使用from行从上一阶段中选取):
FROM python:3.6 as baseRUN apt-get update && apt-get upgrade -yRUN pip install pipenv pipCOPY Pipfile ./# some more common configuration...FROM base as devRUN pipenv install --system --skip-lock --devENV FLASK_ENV developmentENV FLASK_DEBUG 1FROM base as prodRUN pipenv install --system --skip-lockENV FLASK_ENV production
然后,您可以使用
--target要构建的语法来构建一个阶段或另一个阶段,或者构建一个类似于以下内容的文件:
# docker-compose.ymlversion: '3.4'services: webapp: build: context: ./dir dockerfile: Dockerfile target: prod
最大的缺点是当前的构建引擎将经历每个阶段,直到达到目标为止。构建缓存可能意味着仅需不到一秒钟的时间。BuildKit将于18.09进行实验,并且需要docker-
compose的上游支持,它将更加智能,使其仅运行所需的命令即可构建所需的目标。
说了这么多,我相信这是在试图将方钉固定在圆孔中。docker-
compose开发人员鼓励用户远离在compose文件本身中进行构建,因为在swarm模式下不支持该文件。相反,推荐的解决方案是使用CI /
CD构建服务器执行构建,然后将这些映像推送到注册表。然后,你可以运行相同撰写文件
docker-compose或者
docker stackdeploy甚至是一些K8S等价物,而无需重新设计工作流程。



