Refactored Dockerfile

This commit is contained in:
Yurii Vlasov 2023-01-27 19:41:48 +02:00
parent 40411e4100
commit aaaa50a75a
2 changed files with 24 additions and 43 deletions

View File

@ -1,51 +1,39 @@
# syntax=docker/dockerfile:1
# ┬─┐┬ ┐o┬ ┬─┐
# │─││ │││ │ │
# ┘─┘┘─┘┘┘─┘┘─┘
############## FROM techknowlogick/xgo:go-1.19.2 AS builder
# Build stage
FROM --platform=$BUILDPLATFORM techknowlogick/xgo:go-1.19.2 AS build-env
RUN \ RUN go install github.com/magefile/mage@latest && \
go install github.com/magefile/mage@latest && \ mv /go/bin/mage /usr/local/go/bin
mv /go/bin/mage /usr/local/go/bin
ARG VIKUNJA_VERSION
# Setup repo
COPY . /go/src/code.vikunja.io/api
WORKDIR /go/src/code.vikunja.io/api WORKDIR /go/src/code.vikunja.io/api
COPY . ./
ARG TARGETOS TARGETARCH TARGETVARIANT ARG TARGETOS TARGETARCH TARGETVARIANT
# Checkout version if set
RUN if [ -n "${VIKUNJA_VERSION}" ]; then git checkout "${VIKUNJA_VERSION}"; fi && \
mage build:clean && \
mage release:xgo $TARGETOS/$TARGETARCH/$TARGETVARIANT
################### RUN mage build:clean && \
mage release:xgo "${TARGETOS}/${TARGETARCH}/${TARGETVARIANT}"
# ┬─┐┬ ┐┌┐┐┌┐┐┬─┐┬─┐
# │┬┘│ │││││││├─ │┬┘
# ┘└┘┘─┘┘└┘┘└┘┴─┘┘└┘
# The actual image # The actual image
# Note: I wanted to use the scratch image here, but unfortunatly the go-sqlite bindings require cgo and # Note: I wanted to use the scratch image here, but unfortunatly the go-sqlite bindings require cgo and
# because of this, the container would not start when I compiled the image without cgo. # because of this, the container would not start when I compiled the image without cgo.
FROM alpine:3.16 FROM alpine:3.16 AS runner
LABEL maintainer="maintainers@vikunja.io" LABEL maintainer="maintainers@vikunja.io"
WORKDIR /app/vikunja/ WORKDIR /app/vikunja/
COPY --from=build-env /build/vikunja-* vikunja
ENTRYPOINT [ "/app/vikunja/vikunja" ]
ENV VIKUNJA_SERVICE_ROOTPATH=/app/vikunja/ ENV VIKUNJA_SERVICE_ROOTPATH=/app/vikunja/
# Dynamic permission changing stuff RUN apk --update --no-cache add tzdata && \
ENV PUID 1000 addgroup -g 1000 vikunja && \
ENV PGID 1000 adduser -s /bin/sh -D -G vikunja -u 1000 vikunja -h /app/vikunja -H && \
RUN apk --no-cache add shadow && \ mkdir files && \
addgroup -g ${PGID} vikunja && \ chown vikunja:vikunja files
adduser -s /bin/sh -D -G vikunja -u ${PUID} vikunja -h /app/vikunja -H && \
chown vikunja -R /app/vikunja
COPY run.sh /run.sh
# Add time zone data COPY --from=builder --chown=vikunja:vikunja /build/vikunja-* vikunja
RUN apk --no-cache add tzdata
# Files permissions
RUN mkdir /app/vikunja/files && \
chown -R vikunja /app/vikunja/files
VOLUME /app/vikunja/files
CMD ["/run.sh"]
EXPOSE 3456

7
run.sh
View File

@ -1,7 +0,0 @@
#!/bin/sh
# Set the uid and gid of the vikunja run user
usermod --non-unique --uid ${PUID} vikunja
groupmod --non-unique --gid ${PGID} vikunja
exec su vikunja -c '/app/vikunja/vikunja'