| 123456789101112131415161718192021222324 |
- # This version of Dockerfile is for building without external dependencies.
- # Build a multi-platform image e.g. `docker buildx build --push --platform linux/arm64,linux/amd64 --tag external-secrets:dev --file Dockerfile.standalone .`
- FROM golang:1.25.4-alpine@sha256:d3f0cf7723f3429e3f9ed846243970b20a2de7bae6a5b66fc5914e228d831bbb AS builder
- # Add metadata
- LABEL maintainer="cncf-externalsecretsop-maintainers@lists.cncf.io" \
- description="External Secrets Operator is a Kubernetes operator that integrates external secret management systems"
- ARG TARGETOS
- ARG TARGETARCH
- ENV CGO_ENABLED=0 GOOS=${TARGETOS} GOARCH=${TARGETARCH}
- WORKDIR /app
- # Avoid invalidating the `go mod download` cache when only code has changed.
- COPY go.mod go.sum /app/
- RUN go mod download
- COPY . /app/
- RUN go build -o external-secrets main.go
- FROM gcr.io/distroless/static@sha256:87bce11be0af225e4ca761c40babb06d6d559f5767fbf7dc3c47f0f1a466b92c AS app
- COPY --from=builder /app/external-secrets /bin/external-secrets
- # Run as UID for nobody
- USER 65534
- ENTRYPOINT ["/bin/external-secrets"]
|