FROM golang:1.26-bookworm AS builder WORKDIR /src # Cache deps first COPY go.mod go.sum ./ RUN go mod download # Copy source and build COPY . . RUN CGO_ENABLED=0 GOOS=linux GOARCH=amd64 \ go build -trimpath -ldflags="-s -w" -o /out/api ./cmd/api # Small runtime image FROM gcr.io/distroless/static-debian12 WORKDIR /app COPY --from=builder /out/api /app/api EXPOSE 8080 USER nonroot:nonroot ENTRYPOINT ["/app/api"]