10

我是 docker 新手,正在尝试探索多阶段构建。我想在 docker 上运行一个特定的阶段docker build -t build-stage-tag --target build

我希望它运行以下阶段dependencies --> compile --> build并跳过test. 但碰巧它也运行测试阶段。

如果我对多阶段构建的理解--target是错误的,或者我的 docker 文件中有一些错误,请告诉我。

我想做的是在build不运行的情况下运行舞台,test反之亦然。

这就是我的 Dockerfile 的样子:

# Pull base image
FROM openjdk:8u171 as dependencies

# Install Scala
## Piping curl directly in tar
// do some stuff

# Copy source into container
COPY . /usr/src/app

FROM dependencies as compile
WORKDIR /usr/src/app
# Test and build the jar in the same step to save time
RUN sbt -Dsbt.log.noformat=true compile
RUN sbt -Dsbt.log.noformat=true assembly

FROM compile as test
WORKDIR /usr/src/app
RUN sbt -Dsbt.log.noformat=true -Dtest_db_user=root -Dtest_db_password=password -Dtest_db_host=localhost coverage test coverageReport

FROM compile as build

# Define working directory
WORKDIR /root

COPY --from=compile /usr/src/push/target/scala-2.12/app-assembly-?*.?*.?*.jar ./push.jar
COPY --from=compile /usr/src/push/config/jvm.config ./jvm.config
COPY --from=compile /usr/src/push/entrypoint.sh /bin/entrypoint.sh

RUN chmod +x /bin/entrypoint.sh
ENTRYPOINT ["/bin/entrypoint.sh"]
CMD ["docker", "blah"]
4

1 回答 1

4

设置DOCKER_BUILDKIT=1环境变量以使用 buildkit,如下所示:

DOCKER_BUILDKIT=1 docker build -t build-stage-tag --target build -<<EOF
FROM alpine as base
RUN echo "running BASE commands"

FROM base AS test
RUN echo "running TEST commands"

FROM base AS build
RUN echo "running BUILD commands"
EOF

输出:

[+] Building 4.4s (7/7) FINISHED
 => [internal] load .dockerignore                                                                                                                               0.5s
 => => transferring context: 2B                                                                                                                                 0.0s
 => [internal] load build definition from Dockerfile                                                                                                            0.3s
 => => transferring dockerfile: 204B                                                                                                                            0.0s
 => [internal] load metadata for docker.io/library/alpine:latest                                                                                                0.0s
 => [base 1/2] FROM docker.io/library/alpine                                                                                                                    0.1s
 => => resolve docker.io/library/alpine:latest                                                                                                                  0.0s
 => [base 2/2] RUN echo "running BASE commands"                                                                                                                 1.4s
 => [build 1/1] RUN echo "running BUILD commands"                                                                                                               1.5s
 => exporting to image                                                                                                                                          0.7s
 => => exporting layers                                                                                                                                         0.6s
 => => writing image sha256:c6958c8bb64b1c6d5a975d8fa4b68c713ee5b374ba9a9fa00f8a0b9b5b314d5e                                                                    0.0s
 => => naming to docker.io/library/build-stage-tag                                                                                                              0.0s
于 2020-03-02T06:39:55.697 回答