| |
| |
| |
| |
| |
| |
| |
|
|
| ARG NODE_IMAGE=node:24-alpine |
| ARG GOLANG_IMAGE=golang:1.26.1-alpine |
| ARG ALPINE_IMAGE=alpine:3.20 |
| ARG GOPROXY=https://goproxy.cn,direct |
| ARG GOSUMDB=sum.golang.google.cn |
|
|
| |
| |
| |
| FROM ${NODE_IMAGE} AS frontend-builder |
|
|
| WORKDIR /app/frontend |
|
|
| |
| RUN corepack enable && corepack prepare pnpm@latest --activate |
|
|
| |
| COPY frontend/package.json frontend/pnpm-lock.yaml ./ |
| RUN pnpm install --frozen-lockfile |
|
|
| |
| COPY frontend/ ./ |
| RUN pnpm run build |
|
|
| |
| |
| |
| FROM ${GOLANG_IMAGE} AS backend-builder |
|
|
| |
| ARG VERSION=docker |
| ARG COMMIT=docker |
| ARG DATE |
| ARG GOPROXY |
| ARG GOSUMDB |
|
|
| ENV GOPROXY=${GOPROXY} |
| ENV GOSUMDB=${GOSUMDB} |
|
|
| |
| RUN apk add --no-cache git ca-certificates tzdata |
|
|
| WORKDIR /app/backend |
|
|
| |
| COPY backend/go.mod backend/go.sum ./ |
| RUN go mod download |
|
|
| |
| COPY backend/ ./ |
|
|
| |
| COPY --from=frontend-builder /app/backend/internal/web/dist ./internal/web/dist |
|
|
| |
| RUN CGO_ENABLED=0 GOOS=linux go build \ |
| -tags embed \ |
| -ldflags="-s -w -X main.Commit=${COMMIT} -X main.Date=${DATE:-$(date -u +%Y-%m-%dT%H:%M:%SZ)} -X main.BuildType=release" \ |
| -o /app/sub2api \ |
| ./cmd/server |
| |
| |
| |
| |
| FROM ${ALPINE_IMAGE} |
|
|
| |
| LABEL maintainer="Wei-Shaw <github.com/Wei-Shaw>" |
| LABEL description="Sub2API - AI API Gateway Platform" |
| LABEL org.opencontainers.image.source="https://github.com/Wei-Shaw/sub2api" |
|
|
| |
| RUN apk add --no-cache \ |
| ca-certificates \ |
| tzdata \ |
| curl \ |
| su-exec \ |
| && rm -rf /var/cache/apk/* |
|
|
| # Create non-root user |
| RUN addgroup -g 1000 sub2api && \ |
| adduser -u 1000 -G sub2api -s /bin/sh -D sub2api |
|
|
| # Set working directory |
| WORKDIR /app |
|
|
| # Copy binary from builder |
| COPY --from=backend-builder /app/sub2api /app/sub2api |
|
|
| # Create data directory |
| RUN mkdir -p /app/data && chown -R sub2api:sub2api /app |
|
|
| # Copy entrypoint script (fixes volume permissions then drops to sub2api) |
| COPY deploy/docker-entrypoint.sh /app/docker-entrypoint.sh |
| RUN chmod +x /app/docker-entrypoint.sh |
|
|
| # Expose port (can be overridden by SERVER_PORT env var) |
| EXPOSE 8080 |
|
|
| # Health check |
| HEALTHCHECK --interval=30s --timeout=10s --start-period=10s --retries=3 \ |
| CMD wget -q -T 5 -O /dev/null http://localhost:${SERVER_PORT:-8080}/health || exit 1 |
|
|
| # Run the application (entrypoint fixes /app/data ownership then execs as sub2api) |
| ENTRYPOINT ["/app/docker-entrypoint.sh"] |
| CMD ["/app/sub2api"] |
|
|