# Build stage FROM golang:1.19-alpine AS builder # Install git and certificates RUN apk add --no-cache git ca-certificates # Set working directory WORKDIR /app # Copy go mod files COPY go.mod go.sum ./ # Download dependencies RUN go mod download # Copy source code COPY . . # Build the application RUN CGO_ENABLED=0 GOOS=linux go build -a -installsuffix cgo -ldflags '-extldflags "-static"' -o /gorz ./cmd/server # Final stage FROM alpine:latest # Install ca-certificates for HTTPS RUN apk --no-cache add ca-certificates # Create non-root user RUN addgroup -g 1000 appgroup && adduser -u 1000 -G appgroup -s /bin/sh -D appuser # Set working directory WORKDIR /app # Copy binary from builder COPY --from=builder /gorz . # Copy config file if it exists COPY config.yaml . # Change ownership RUN chown -R appuser:appgroup /app # Switch to non-root user USER appuser # Expose ports EXPOSE 8080 9090 # Health check HEALTHCHECK --interval=30s --timeout=3s --start-period=5s --retries=3 \ CMD wget --no-verbose --tries=1 --spider http://localhost:8080/health || exit 1 # Run the application CMD ["./gorz"]