# Build stage FROM docker.io/library/golang:1.25-alpine AS builder WORKDIR /app # Copy go mod files COPY go.mod go.sum ./ # Download dependencies RUN go mod download # Copy source code COPY . . # Build the binary RUN CGO_ENABLED=0 GOOS=linux go build -a -installsuffix cgo -o /app/main . # Production stage FROM docker.io/library/alpine:latest AS production # Install ca-certificates for HTTPS and wget for healthcheck RUN apk --no-cache add ca-certificates && \ addgroup -g 1000 appuser && \ adduser -D -u 1000 -G appuser appuser WORKDIR /app # Copy the binary from builder COPY --from=builder --chown=appuser:appuser /app/main /app/main # Switch to non-root user USER appuser EXPOSE 8080 # Health check HEALTHCHECK --interval=30s --timeout=3s --start-period=5s --retries=3 \ CMD wget --no-verbose --tries=1 --spider http://localhost:8080/healthz || exit 1 CMD ["/app/main"]