mirror of
https://github.com/thib8956/nginx-proxy
synced 2025-02-24 01:38:15 +00:00
Enable multi-architecture docker image builds
Previously, the Dockerfile downloaded 'docker-gen' and 'forego' binaries during build time. This caused a problem as it hard-coded the amd64 architecture for the images. This commit updates both 'Dockerfile' and 'Dockerfile.alpine' to build the `forego` and `docker-gen` executables from scratch instead of downloading binaries directly. This is achieved using multi-stage builds [1]. Two seperate stages first build the binaries, and are then copied over to the final stage. The advantage of this change is two-fold: First, it enables building this image on architectures other than amd64. Secondly it adds trust by not adding external binaries to the docker image. This modified version passes the test both a linux desktop (amd64) as well as a raspberry pi (armv7) with some caveats: - On armv7, a modified version of the `jwilder/docker-gen` image is required. See a seperate PR at [2]. - The 'test_dhparam_is_generated_if_missing' test fails. This also doesn't currently pass on master. [1] https://docs.docker.com/develop/develop-images/multistage-build/ [2] https://github.com/jwilder/docker-gen/pull/327
This commit is contained in:
parent
bf2d7295d3
commit
886dd04b62
63
Dockerfile
63
Dockerfile
@ -1,4 +1,50 @@
|
|||||||
FROM nginx:1.19.3
|
# setup build arguments for version of dependencies to use
|
||||||
|
ARG NGINX_VERSION=1.19.3
|
||||||
|
ARG GO_VERSION=1.14
|
||||||
|
|
||||||
|
ARG DOCKER_GEN_VERSION=0.7.4
|
||||||
|
ARG FOREGO_VERSION=0.16.1
|
||||||
|
|
||||||
|
# Use a specific version of golang to build both binaries
|
||||||
|
FROM golang:$GO_VERSION as gobuilder
|
||||||
|
|
||||||
|
# Build docker-gen from scratch
|
||||||
|
FROM gobuilder as dockergen
|
||||||
|
|
||||||
|
# Download the sources for the given version
|
||||||
|
ARG DOCKER_GEN_VERSION
|
||||||
|
ADD https://github.com/jwilder/docker-gen/archive/${DOCKER_GEN_VERSION}.tar.gz sources.tar.gz
|
||||||
|
|
||||||
|
# Move the sources into the right directory
|
||||||
|
RUN tar -xzf sources.tar.gz && \
|
||||||
|
mkdir -p /go/src/github.com/jwilder/ && \
|
||||||
|
mv docker-gen-* /go/src/github.com/jwilder/docker-gen
|
||||||
|
|
||||||
|
# Install the dependencies and make the docker-gen executable
|
||||||
|
WORKDIR /go/src/github.com/jwilder/docker-gen
|
||||||
|
RUN go get -v ./... && \
|
||||||
|
CGO_ENABLED=0 GOOS=linux go build -ldflags "-X main.buildVersion=${DOCKER_GEN_VERSION}" ./cmd/docker-gen
|
||||||
|
|
||||||
|
# Build forego from scratch
|
||||||
|
# Because this relies on golang workspaces, we need to use go < 1.8.
|
||||||
|
FROM gobuilder as forego
|
||||||
|
|
||||||
|
# Download the sources for the given version
|
||||||
|
ARG FOREGO_VERSION
|
||||||
|
ADD https://github.com/jwilder/forego/archive/v${FOREGO_VERSION}.tar.gz sources.tar.gz
|
||||||
|
|
||||||
|
# Move the sources into the right directory
|
||||||
|
RUN tar -xzf sources.tar.gz && \
|
||||||
|
mkdir -p /go/src/github.com/ddollar/ && \
|
||||||
|
mv forego-* /go/src/github.com/ddollar/forego
|
||||||
|
|
||||||
|
# Install the dependencies and make the forego executable
|
||||||
|
WORKDIR /go/src/github.com/ddollar/forego/
|
||||||
|
RUN go get -v ./... && \
|
||||||
|
CGO_ENABLED=0 GOOS=linux go build -o forego .
|
||||||
|
|
||||||
|
# Build the final image
|
||||||
|
FROM nginx:$NGINX_VERSION
|
||||||
LABEL maintainer="Jason Wilder mail@jasonwilder.com"
|
LABEL maintainer="Jason Wilder mail@jasonwilder.com"
|
||||||
|
|
||||||
# Install wget and install/updates certificates
|
# Install wget and install/updates certificates
|
||||||
@ -14,15 +60,14 @@ RUN apt-get update \
|
|||||||
RUN echo "daemon off;" >> /etc/nginx/nginx.conf \
|
RUN echo "daemon off;" >> /etc/nginx/nginx.conf \
|
||||||
&& sed -i 's/worker_processes 1/worker_processes auto/' /etc/nginx/nginx.conf
|
&& sed -i 's/worker_processes 1/worker_processes auto/' /etc/nginx/nginx.conf
|
||||||
|
|
||||||
# Install Forego
|
# Install Forego + docker-gen
|
||||||
ADD https://github.com/jwilder/forego/releases/download/v0.16.1/forego /usr/local/bin/forego
|
COPY --from=forego /go/src/github.com/ddollar/forego/forego /usr/local/bin/forego
|
||||||
RUN chmod u+x /usr/local/bin/forego
|
COPY --from=dockergen /go/src/github.com/jwilder/docker-gen/docker-gen /usr/local/bin/docker-gen
|
||||||
|
|
||||||
ENV DOCKER_GEN_VERSION 0.7.4
|
# Add DOCKER_GEN_VERSION environment variable
|
||||||
|
# Because some external projects rely on it
|
||||||
RUN wget https://github.com/jwilder/docker-gen/releases/download/$DOCKER_GEN_VERSION/docker-gen-linux-amd64-$DOCKER_GEN_VERSION.tar.gz \
|
ARG DOCKER_GEN_VERSION
|
||||||
&& tar -C /usr/local/bin -xvzf docker-gen-linux-amd64-$DOCKER_GEN_VERSION.tar.gz \
|
ENV DOCKER_GEN_VERSION=${DOCKER_GEN_VERSION}
|
||||||
&& rm /docker-gen-linux-amd64-$DOCKER_GEN_VERSION.tar.gz
|
|
||||||
|
|
||||||
COPY network_internal.conf /etc/nginx/
|
COPY network_internal.conf /etc/nginx/
|
||||||
|
|
||||||
|
@ -1,4 +1,51 @@
|
|||||||
FROM nginx:1.19.3-alpine
|
# setup build arguments for version of dependencies to use
|
||||||
|
ARG NGINX_VERSION=1.19.3-alpine
|
||||||
|
ARG GO_VERSION=1.14-alpine
|
||||||
|
|
||||||
|
ARG DOCKER_GEN_VERSION=0.7.4
|
||||||
|
ARG FOREGO_VERSION=0.16.1
|
||||||
|
|
||||||
|
# Use a specific version of golang to build both binaries
|
||||||
|
FROM golang:$GO_VERSION as gobuilder
|
||||||
|
RUN apk add --no-cache git
|
||||||
|
|
||||||
|
# Build docker-gen from scratch
|
||||||
|
FROM gobuilder as dockergen
|
||||||
|
|
||||||
|
# Download the sources for the given version
|
||||||
|
ARG DOCKER_GEN_VERSION
|
||||||
|
ADD https://github.com/jwilder/docker-gen/archive/${DOCKER_GEN_VERSION}.tar.gz sources.tar.gz
|
||||||
|
|
||||||
|
# Move the sources into the right directory
|
||||||
|
RUN tar -xzf sources.tar.gz && \
|
||||||
|
mkdir -p /go/src/github.com/jwilder/ && \
|
||||||
|
mv docker-gen-* /go/src/github.com/jwilder/docker-gen
|
||||||
|
|
||||||
|
# Install the dependencies and make the docker-gen executable
|
||||||
|
WORKDIR /go/src/github.com/jwilder/docker-gen
|
||||||
|
RUN go get -v ./... && \
|
||||||
|
CGO_ENABLED=0 GOOS=linux go build -ldflags "-X main.buildVersion=${DOCKER_GEN_VERSION}" ./cmd/docker-gen
|
||||||
|
|
||||||
|
# Build forego from scratch
|
||||||
|
# Because this relies on golang workspaces, we need to use go < 1.8.
|
||||||
|
FROM gobuilder as forego
|
||||||
|
|
||||||
|
# Download the sources for the given version
|
||||||
|
ARG FOREGO_VERSION
|
||||||
|
ADD https://github.com/jwilder/forego/archive/v${FOREGO_VERSION}.tar.gz sources.tar.gz
|
||||||
|
|
||||||
|
# Move the sources into the right directory
|
||||||
|
RUN tar -xzf sources.tar.gz && \
|
||||||
|
mkdir -p /go/src/github.com/ddollar/ && \
|
||||||
|
mv forego-* /go/src/github.com/ddollar/forego
|
||||||
|
|
||||||
|
# Install the dependencies and make the forego executable
|
||||||
|
WORKDIR /go/src/github.com/ddollar/forego/
|
||||||
|
RUN go get -v ./... && \
|
||||||
|
CGO_ENABLED=0 GOOS=linux go build -o forego .
|
||||||
|
|
||||||
|
# Build the final image
|
||||||
|
FROM nginx:$NGINX_VERSION
|
||||||
LABEL maintainer="Jason Wilder mail@jasonwilder.com"
|
LABEL maintainer="Jason Wilder mail@jasonwilder.com"
|
||||||
|
|
||||||
# Install wget and install/updates certificates
|
# Install wget and install/updates certificates
|
||||||
@ -11,15 +58,14 @@ RUN apk add --no-cache --virtual .run-deps \
|
|||||||
RUN echo "daemon off;" >> /etc/nginx/nginx.conf \
|
RUN echo "daemon off;" >> /etc/nginx/nginx.conf \
|
||||||
&& sed -i 's/worker_processes 1/worker_processes auto/' /etc/nginx/nginx.conf
|
&& sed -i 's/worker_processes 1/worker_processes auto/' /etc/nginx/nginx.conf
|
||||||
|
|
||||||
# Install Forego
|
# Install Forego + docker-gen
|
||||||
ADD https://github.com/jwilder/forego/releases/download/v0.16.1/forego /usr/local/bin/forego
|
COPY --from=forego /go/src/github.com/ddollar/forego/forego /usr/local/bin/forego
|
||||||
RUN chmod u+x /usr/local/bin/forego
|
COPY --from=dockergen /go/src/github.com/jwilder/docker-gen/docker-gen /usr/local/bin/docker-gen
|
||||||
|
|
||||||
ENV DOCKER_GEN_VERSION 0.7.4
|
# Add DOCKER_GEN_VERSION environment variable
|
||||||
|
# Because some external projects rely on it
|
||||||
RUN wget --quiet https://github.com/jwilder/docker-gen/releases/download/$DOCKER_GEN_VERSION/docker-gen-alpine-linux-amd64-$DOCKER_GEN_VERSION.tar.gz \
|
ARG DOCKER_GEN_VERSION
|
||||||
&& tar -C /usr/local/bin -xvzf docker-gen-alpine-linux-amd64-$DOCKER_GEN_VERSION.tar.gz \
|
ENV DOCKER_GEN_VERSION=${DOCKER_GEN_VERSION}
|
||||||
&& rm /docker-gen-alpine-linux-amd64-$DOCKER_GEN_VERSION.tar.gz
|
|
||||||
|
|
||||||
COPY network_internal.conf /etc/nginx/
|
COPY network_internal.conf /etc/nginx/
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user