我现在有一些 Dockerfile。
一个用于 Cassandra 3.5,它是 FROM cassandra:3.5
我还有一个用于 Kafka 的 Dockerfile,但要复杂得多。它是FROM java:openjdk-8-fre
,它运行一个很长的命令来安装Kafka和Zookeeper。
最后,我有一个使用 SBT 的 Scala 编写的应用程序。
对于那个 Dockerfile,它是 FROM broadinstitute/scala-baseimage
,它为我提供了我需要的 Java 8、Scala 2.11.7 和 STB 0.13.9。
也许,我不明白 Docker 是如何工作的,但我的 Scala 程序有 Cassandra 和 Kafka 作为依赖项,出于开发目的,我希望其他人能够使用 Dockerfile
简单地克隆我的 repo然后能够使用 Cassandra、Kafka、Scala、Java 和 SBT 构建它,这样他们就可以编译源代码。不过,我对此有很多问题。
如何组合这些 Dockerfile?我如何简单地制作一个包含这些东西的环境?
最佳答案
您可以使用 Docker 1.17 中引入的多阶段构建功能
看看这个:
FROM golang:1.7.3
WORKDIR /go/src/github.com/alexellis/href-counter/
RUN go get -d -v golang.org/x/net/html
COPY app.go .
RUN CGO_ENABLED=0 GOOS=linux go build -a -installsuffix cgo -o app .
FROM alpine:latest
RUN apk --no-cache add ca-certificates
WORKDIR /root/
COPY --from=0 /go/src/github.com/alexellis/href-counter/app .
CMD ["./app"]
然后正常构建镜像:
docker build -t alexellis2/href-counter:latest
发件人:https://docs.docker.com/develop/develop-images/multistage-build/
The end result is the same tiny production image as before, with a significant reduction in complexity. You don’t need to create any intermediate images and you don’t need to extract any artifacts to your local system at all.
How does it work? The second FROM instruction starts a new build stage with the alpine:latest image as its base. The COPY --from=0 line copies just the built artifact from the previous stage into this new stage. The Go SDK and any intermediate artifacts are left behind, and not saved in the final image.
关于docker - 有没有办法将 Docker 镜像组合到 1 个容器中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39626579/