# --- # Stage 1: Install certs, build binary, create default config file # --- FROM ghcr.io/project-zot/golang:1.19 AS builder RUN mkdir -p /go/src/github.com/project-zot/zot WORKDIR /go/src/github.com/project-zot/zot COPY . . RUN make clean binary RUN echo '{\n\ "storage": {\n\ "rootDirectory": "/var/lib/registry"\n\ },\n\ "http": {\n\ "address": "0.0.0.0",\n\ "port": "5000"\n\ },\n\ "log": {\n\ "level": "debug"\n\ },\n\ "extensions": {\n\ "metrics": {\n\ "enable": true,\n\ "prometheus": {\n\ "path": "/metrics"\n\ }\n\ }\n\ }\n\ }\n' > config.json && cat config.json # --- # Stage 2: Final image with nothing but certs, binary, and default config file # --- FROM gcr.io/distroless/base AS final COPY --from=builder /etc/ssl/certs/ca-certificates.crt /etc/ssl/certs/ca-certificates.crt COPY --from=builder /go/src/github.com/project-zot/zot/bin/zot-linux-amd64 /usr/bin/zot COPY --from=builder /go/src/github.com/project-zot/zot/config.json /etc/zot/config.json ENTRYPOINT ["/usr/bin/zot"] EXPOSE 5000 VOLUME ["/var/lib/registry"] CMD ["serve", "/etc/zot/config.json"]