# Build stage FROM golang:1.22-alpine AS builder WORKDIR /app RUN apk add --no-cache git COPY go.mod go.sum* ./ RUN go mod download COPY . . RUN CGO_ENABLED=0 GOOS=linux go build -a -installsuffix cgo -o compliance-engine . # Runtime stage FROM alpine:3.19 WORKDIR /app RUN apk --no-cache add ca-certificates COPY --from=builder /app/compliance-engine . COPY --from=builder /app/policies ./policies RUN adduser -D -g '' appuser USER appuser EXPOSE 8081 HEALTHCHECK --interval=30s --timeout=3s --start-period=5s --retries=3 \ CMD wget --no-verbose --tries=1 --spider http://localhost:8081/health || exit 1 CMD ["./compliance-engine"]