ci(build): pull Docker Hub base images via Nexus mirror + kargadan GOPROXY
CI/CD / CI · Web (tsc) (push) Successful in 1m8s
CI/CD / Deploy · full stack (push) Failing after 7s

Docker Hub blocks Iran (403) on the BUILD base images too (golang/alpine/busybox/
node) once they fall out of cache. Prefix every Docker Hub FROM/COPY --from with
mirror.soroushasadi.com/ (MCR dotnet images are reachable, left as-is). Go builders
also set GOPROXY=mirror.kargadan.ir/repository/go-group/ + GOSUMDB=off so any module/
toolchain fetch avoids the geo-blocked proxy.golang.org.

Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
This commit is contained in:
soroush.asadi
2026-06-12 16:24:38 +03:30
parent 18cdf507f0
commit ee2a6b9b60
8 changed files with 19 additions and 14 deletions
+3 -3
View File
@@ -1,5 +1,5 @@
# ── Stage 1: install dependencies ────────────────────────────────────────────
FROM node:20-alpine AS deps
FROM mirror.soroushasadi.com/node:20-alpine AS deps
RUN apk add --no-cache libc6-compat
WORKDIR /app
@@ -18,7 +18,7 @@ RUN for i in 1 2 3 4 5; do \
echo "npm ci failed after 5 attempts" && exit 1
# ── Stage 2: build ───────────────────────────────────────────────────────────
FROM node:20-alpine AS builder
FROM mirror.soroushasadi.com/node:20-alpine AS builder
WORKDIR /app
COPY --from=deps /app/node_modules ./node_modules
@@ -51,7 +51,7 @@ ENV NODE_ENV=production
RUN npm run build
# ── Stage 3: production runner ────────────────────────────────────────────────
FROM node:20-alpine AS runner
FROM mirror.soroushasadi.com/node:20-alpine AS runner
WORKDIR /app
ENV NODE_ENV=production