docker - docker compose 中的多阶段构建?

标签 docker docker-compose

如何在 docker-compose.yml 中指定多阶段构建?

对于每个变体(例如 dev、prod...),我都有一个包含 2 个 docker 文件的多阶段构建:

  • 开发:Dockerfile.base + Dockerfile.dev
  • 或产品:Dockerfile.base + Dockerfile.prod

文件 Dockerfile.base(所有变体通用):

FROM python:3.6
RUN apt-get update && apt-get upgrade -y
RUN pip install pipenv pip
COPY Pipfile ./
# some more common configuration...

文件Dockerfile.dev:

FROM flaskapp:base
RUN pipenv install --system --skip-lock --dev
ENV FLASK_ENV development
ENV FLASK_DEBUG 1

文件Dockerfile.prod:

FROM flaskapp:base
RUN pipenv install --system --skip-lock
ENV FLASK_ENV production

没有 docker-compose,我可以构建为:

# Building dev
docker build --tag flaskapp:base -f Dockerfile.base .
docker build --tag flaskapp:dev -f Dockerfile.dev .
# or building prod
docker build --tag flaskapp:base -f Dockerfile.base .
docker build --tag flaskapp:dev -f Dockerfile.dev .

根据compose-file doc ,我可以指定一个 Dockerfile 来构建。

# docker-compose.yml
version: '3'
services:
  webapp:
    build:
      context: ./dir
      dockerfile: Dockerfile-alternate

但是如何在 docker-compose.yml 中指定 2 个 Dockerfile(用于多阶段构建)?

最佳答案

正如评论中提到的,多阶段构建涉及单个 Dockerfile 来执行多个阶段。你所拥有的是一个通用的基础镜像。

您可以使用以下语法将这些转换为非传统的多阶段构建(我说非传统的,因为您不在层之间执行任何复制,而是仅使用 from 行从前一阶段中选择) :

FROM python:3.6 as base
RUN apt-get update && apt-get upgrade -y
RUN pip install pipenv pip
COPY Pipfile ./
# some more common configuration...

FROM base as dev
RUN pipenv install --system --skip-lock --dev
ENV FLASK_ENV development
ENV FLASK_DEBUG 1

FROM base as prod
RUN pipenv install --system --skip-lock
ENV FLASK_ENV production

然后您可以使用 --target 语法构建一个或另一个阶段,或者像这样的 compose 文件:

# docker-compose.yml
version: '3.4'
services:
  webapp:
    build:
      context: ./dir
      dockerfile: Dockerfile
      target: prod

最大的缺点是当前的构建引擎会经历每个阶段,直到达到目标。构建缓存可能意味着这只是一个亚秒级的过程。 BuildKit 将在 18.09 中进行实验,需要 docker-compose 的上游支持,它将更加智能地只运行所需的命令来构建您想要的目标。

话虽如此,我相信这是试图将方形钉子安装在圆孔中。 docker-compose 开发人员鼓励用户不要在 compose 文件本身中进行构建,因为它在 swarm 模式下不受支持。相反,推荐的解决方案是使用 CI/CD 构建服务器执行构建,并将这些图像推送到注册表。然后,您可以使用 docker-composedocker stack deploy 甚至一些 k8s 等效项运行相同的 compose 文件,而无需重新设计工作流程。

关于docker - docker compose 中的多阶段构建?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53093487/

相关文章:

docker - 如何在Docker Toolbox中访问容器服务器

docker - 如何将主机名从主机解析为 Docker 容器?

docker - 如何在 Windows 10 上更新 docker-compose 版本

"host"网络模式下的docker没有给主机绑定(bind)端口

docker - 将ENTRYPOINT和CMD结合到Dockerfile中以不同的可执行文件为目标

hadoop - 在 Docker 容器上使用 Hadoop 和 Spark

docker - 无法与docker-compose一起使用.env文件

mongodb - 如何将参数从docker-compose传递到docker image中运行的服务?

angular - 如何在使用 jib 时创建 docker-compose.yml 文件?

Docker:错误抓取日志:无效字符 '\x00' 寻找值的开头