Improve the Docker image
This commit is contained in:
parent
f926981e02
commit
89b245d0e9
|
@ -0,0 +1,7 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
[ -n "${PUID}" ] && usermod -u "${PUID}" msgbus
|
||||||
|
[ -n "${PGID}" ] && groupmod -g "${PGID}" msgbus
|
||||||
|
|
||||||
|
printf "Switching UID=%s and GID=%s\n" "${PUID}" "${PGID}"
|
||||||
|
exec su-exec msgbus:msgbus "$@"
|
|
@ -1,2 +1,14 @@
|
||||||
|
Dockerfile
|
||||||
|
|
||||||
*~
|
*~
|
||||||
*.bak
|
*.bak
|
||||||
|
.DS_Store
|
||||||
|
*.idea
|
||||||
|
|
||||||
|
/dist
|
||||||
|
|
||||||
|
/msgbus
|
||||||
|
/msgbusd
|
||||||
|
|
||||||
|
/cmd/msgbus/msgbus
|
||||||
|
/cmd/msgbusd/msgbusd
|
||||||
|
|
74
Dockerfile
74
Dockerfile
|
@ -1,35 +1,65 @@
|
||||||
# Build
|
# Build
|
||||||
FROM golang:alpine AS build
|
FROM golang:alpine AS build
|
||||||
|
|
||||||
ARG TAG
|
RUN apk add --no-cache -U build-base git make
|
||||||
ARG BUILD
|
|
||||||
|
|
||||||
ENV LIBRARY msgbus
|
RUN mkdir -p /src
|
||||||
ENV SERVER msgbusd
|
|
||||||
ENV CLIENT msgbus
|
|
||||||
ENV REPO prologic/$LIBRARY
|
|
||||||
|
|
||||||
RUN apk add --update git make build-base && \
|
WORKDIR /src
|
||||||
rm -rf /var/cache/apk/*
|
|
||||||
|
|
||||||
WORKDIR /go/src/github.com/$REPO
|
# Copy Makefile
|
||||||
COPY . /go/src/github.com/$REPO
|
COPY Makefile ./
|
||||||
RUN make TAG=$TAG BUILD=$BUILD build
|
|
||||||
|
# Install deps
|
||||||
|
RUN make deps
|
||||||
|
|
||||||
|
# Copy go.mod and go.sum and install and cache dependencies
|
||||||
|
COPY go.mod .
|
||||||
|
COPY go.sum .
|
||||||
|
|
||||||
|
# Copy sources
|
||||||
|
COPY *.go ./
|
||||||
|
COPY ./client/*.go ./client/
|
||||||
|
COPY ./cmd/msgbusd/*.go ./cmd/msgbusd/
|
||||||
|
COPY ./cmd/msgbus/*.go ./cmd/msgbus/
|
||||||
|
|
||||||
|
# Version/Commit (there there is no .git in Docker build context)
|
||||||
|
# NOTE: This is fairly low down in the Dockerfile instructions so
|
||||||
|
# we don't break the Docker build cache just be changing
|
||||||
|
# unrelated files that actually haven't changed but caused the
|
||||||
|
# COMMIT value to change.
|
||||||
|
ARG VERSION="0.0.0"
|
||||||
|
ARG COMMIT="HEAD"
|
||||||
|
|
||||||
|
# Build client binary
|
||||||
|
RUN make cli VERSION=$VERSION COMMIT=$COMMIT
|
||||||
|
|
||||||
|
# Build server binary
|
||||||
|
RUN make server VERSION=$VERSION COMMIT=$COMMIT
|
||||||
|
|
||||||
# Runtime
|
# Runtime
|
||||||
FROM scratch
|
FROM alpine:latest
|
||||||
|
|
||||||
ENV LIBRARY msgbus
|
RUN apk --no-cache -U add su-exec shadow ca-certificates tzdata
|
||||||
ENV SERVER msgbusd
|
|
||||||
ENV CLIENT msgbus
|
|
||||||
ENV REPO prologic/$LIBRARY
|
|
||||||
|
|
||||||
LABEL msgbud.app main
|
ENV PUID=1000
|
||||||
|
ENV PGID=1000
|
||||||
|
|
||||||
COPY --from=build /go/src/github.com/${REPO}/cmd/${SERVER}/${SERVER} /${SERVER}
|
RUN addgroup -g "${PGID}" msgbus && \
|
||||||
COPY --from=build /go/src/github.com/${REPO}/cmd/${CLIENT}/${CLIENT} /${CLIENT}
|
adduser -D -H -G msgbus -h /var/empty -u "${PUID}" msgbus && \
|
||||||
|
mkdir -p /data && chown -R msgbus:msgbus /data
|
||||||
|
|
||||||
EXPOSE 8000/tcp
|
VOLUME /data
|
||||||
|
|
||||||
ENTRYPOINT ["/msgbusd"]
|
WORKDIR /
|
||||||
CMD []
|
|
||||||
|
# force cgo resolver
|
||||||
|
ENV GODEBUG=netdns=cgo
|
||||||
|
|
||||||
|
COPY --from=build /src/msgbusd /usr/local/bin/msgbusd
|
||||||
|
COPY --from=build /src/msgbus /usr/local/bin/msgbus
|
||||||
|
|
||||||
|
COPY .dockerfiles/entrypoint.sh /init
|
||||||
|
|
||||||
|
ENTRYPOINT ["/init"]
|
||||||
|
CMD ["msgbusd"]
|
||||||
|
|
Loading…
Reference in New Issue