当前位置: 首页 > 面试题库 >

在docker中进行多阶段构建?

邵弘伟
2023-03-14
问题内容

如何在中指定多阶段构建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

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


问题答案:

如评论中所述,多阶段构建涉及单个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要构建的语法来构建一个阶段或另一个阶段,或者构建一个类似于以下内容的文件:

# 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-compose或者docker stack deploy甚至是一些K8S等价物,而无需重新设计工作流程。



 类似资料:
  • Docker的口号是 Build,Ship,and Run Any App,Anywhere,在我们使用 Docker 的大部分时候,的确能感觉到其优越性,但是往往在我们 Build 一个应用的时候,是将我们的源代码也构建进去的,这对于类似于 golang 这样的编译型语言肯定是不行的,因为实际运行的时候我只需要把最终构建的二进制包给你就行,把源码也一起打包在镜像中,需要承担很多风险,即使是脚本语

  • FROM alpine:3.9.6 as build ​ # 构建xlswriter扩展,根据自身需要替换版本号 ENV XLSWRITER_VERSION 1.3.4.1 ​ RUN apk update \ && apk add --no-cache php7-pear php7-dev zlib-dev re2c gcc g++ make curl \ && curl -fs

  • 多阶段构建 之前的做法 在 Docker 17.05 版本之前,我们构建 Docker 镜像时,通常会采用两种方式: 全部放入一个 Dockerfile 一种方式是将所有的构建过程编包含在一个 Dockerfile 中,包括项目及其依赖库的编译、测试、打包等流程,这里可能会带来的一些问题: 镜像层次多,镜像体积较大,部署时间变长 源代码存在泄露的风险 例如,编写 app.go 文件,该程序输出 H

  • 问题内容: 我正在努力将我的构建部署到Docker上的AWS上。我不知道解决方案在哪里,因为这是我第一次使用Docker。我已经在本地一切正常,但是当我部署时,在Elastic Beanstalk中出现以下错误: 这是我的Docker文件的样子: 有人可以指出正确的方向吗?还是Elastic Beanstalk的Docker版本不支持这种多阶段构建方法? 问题答案: 使用使用“ Amazon Li

  • 所有这些在本地都能正常工作。然而,当我试图在docker-compose设置中使用它时,它在构建阶段的npm安装步骤中失败了。 DockerFile Docker-compose.yml Dockerise像https://www.vaultproject.io/这样的东西,首先运行它,添加键并在节点容器中使用它来获得最新的键。(缺点:可能有很多工作,可能还有其他问题?) 使用Docker sec

  • 我在代码构建过程的构建阶段遇到以下错误: “执行命令时出错:docker build-t…”原因:退出状态1 我有一个使用ecr权限设置的代码构建服务角色,aws ecr登录阶段已经成功,我的buildspec.yml非常简单——几乎只是标准模板。运行时是亚马逊管理的ubuntu镜像,标准。 Docker构建失败的原因有哪些?有没有人建议进行故障排除? 谢谢你 完整buildspec.yml文件: