18555a3cb2
On systems with low resources the command `go mod download` can fail. This causes long builds of the docker images. This change adds a new layer in the docker build splitting the build and download in two steps. Fixes #1114
35 lines
1.1 KiB
Text
35 lines
1.1 KiB
Text
FROM golang:alpine AS builder
|
|
|
|
WORKDIR /src
|
|
COPY . .
|
|
|
|
RUN apk add --no-cache curl git make
|
|
RUN apk add --no-cache gcc musl-dev pkgconf pcsc-lite-dev
|
|
RUN make V=1 download
|
|
RUN make V=1 GOFLAGS="" build
|
|
|
|
|
|
FROM smallstep/step-cli:latest
|
|
|
|
COPY --from=builder /src/bin/step-ca /usr/local/bin/step-ca
|
|
COPY --from=builder /src/bin/step-awskms-init /usr/local/bin/step-awskms-init
|
|
COPY --from=builder /src/bin/step-cloudkms-init /usr/local/bin/step-cloudkms-init
|
|
COPY --from=builder /src/bin/step-pkcs11-init /usr/local/bin/step-pkcs11-init
|
|
COPY --from=builder /src/bin/step-yubikey-init /usr/local/bin/step-yubikey-init
|
|
|
|
USER root
|
|
RUN apk add --no-cache libcap && setcap CAP_NET_BIND_SERVICE=+eip /usr/local/bin/step-ca
|
|
RUN apk add --no-cache pcsc-lite pcsc-lite-libs
|
|
USER step
|
|
|
|
ENV CONFIGPATH="/home/step/config/ca.json"
|
|
ENV PWDPATH="/home/step/secrets/password"
|
|
|
|
VOLUME ["/home/step"]
|
|
STOPSIGNAL SIGTERM
|
|
HEALTHCHECK CMD step ca health 2>/dev/null | grep "^ok" >/dev/null
|
|
|
|
COPY docker/entrypoint.sh /entrypoint.sh
|
|
|
|
ENTRYPOINT ["/bin/bash", "/entrypoint.sh"]
|
|
CMD exec /usr/local/bin/step-ca --password-file $PWDPATH $CONFIGPATH
|