Browse Source

Fix automatic build and update base image

* Revert to amd64 Dockerfile to fix automatic Docker Hub building and add multiarch image separately instead
* Change base image for the building stage to alpine and update the golang version to latest
* Change the entrypoint path for consistency with base image
* Make use of COPY instead of cloning the git repo in the building stage
* Add missing default lua-metrics-file argument as it is required
master
Manuel 4 years ago
parent
commit
db0c08b5e4
No known key found for this signature in database GPG Key ID: 4085037435E1F07A
  1. 27
      Dockerfile
  2. 23
      Dockerfile.multiarch

27
Dockerfile

@ -1,23 +1,14 @@
FROM --platform=$BUILDPLATFORM golang:1.15 AS build FROM golang:alpine as build
ARG TARGETOS COPY . /usr/src/fritzbox_exporter
ARG TARGETARCH WORKDIR /usr/src/fritzbox_exporter
ARG TARGETVARIANT
RUN git clone https://github.com/chr-fritz/fritzbox_exporter.git /go/src/github.com/chr-fritz/fritzbox_exporter
WORKDIR /go/src/github.com/chr-fritz/fritzbox_exporter
RUN go mod download; \ RUN go mod download; \
case "$TARGETVARIANT" in \ CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -a -ldflags '-w -extldflags "-static"' -o fritzbox-exporter .
v5) export GOARM=5 ;; \
v6) export GOARM=6 ;; \
v7) export GOARM=7 ;; \
esac; \
CGO_ENABLED=0 GOOS=$TARGETOS GOARCH=$TARGETARCH go build -a -ldflags '-w -extldflags "-static"' -o fritzbox-exporter .
FROM --platform=$TARGETPLATFORM alpine:latest FROM alpine:latest
RUN apk --no-cache add ca-certificates RUN apk --no-cache add ca-certificates
COPY --from=build /go/src/github.com/chr-fritz/fritzbox_exporter/fritzbox-exporter /fritzbox-exporter/ COPY --from=build /usr/src/fritzbox_exporter/fritzbox-exporter /bin/
COPY --from=build /go/src/github.com/chr-fritz/fritzbox_exporter/*.json /etc/fritzbox-exporter/ COPY --from=build /usr/src/fritzbox_exporter/*.json /etc/fritzbox-exporter/
ENTRYPOINT ["/fritzbox-exporter/fritzbox-exporter"] ENTRYPOINT ["/bin/fritzbox-exporter"]
CMD ["--metrics-file","/etc/fritzbox-exporter/metrics.json","--listen-address","0.0.0.0:8080"] CMD ["--metrics-file","/etc/fritzbox-exporter/metrics.json","--lua-metrics-file","/etc/fritzbox-exporter/metrics-lua.json","--listen-address","0.0.0.0:8080"]

23
Dockerfile.multiarch

@ -0,0 +1,23 @@
FROM --platform=$BUILDPLATFORM golang:alpine as build
ARG TARGETOS
ARG TARGETARCH
ARG TARGETVARIANT
COPY . /usr/src/fritzbox_exporter
WORKDIR /usr/src/fritzbox_exporter
RUN go mod download; \
case "$TARGETVARIANT" in \
v5) export GOARM=5 ;; \
v6) export GOARM=6 ;; \
v7) export GOARM=7 ;; \
esac; \
CGO_ENABLED=0 GOOS=$TARGETOS GOARCH=$TARGETARCH go build -a -ldflags '-w -extldflags "-static"' -o fritzbox-exporter .
FROM --platform=$TARGETPLATFORM alpine:latest
RUN apk --no-cache add ca-certificates
COPY --from=build /usr/src/fritzbox_exporter/fritzbox-exporter /bin/
COPY --from=build /usr/src/fritzbox_exporter/*.json /etc/fritzbox-exporter/
ENTRYPOINT ["/bin/fritzbox-exporter"]
CMD ["--metrics-file","/etc/fritzbox-exporter/metrics.json","--lua-metrics-file","/etc/fritzbox-exporter/metrics-lua.json","--listen-address","0.0.0.0:8080"]
Loading…
Cancel
Save