- backend/Dockerfile: alpine→slim, add NODE_TLS_REJECT_UNAUTHORIZED=0, 3-stage pattern - web/Dockerfile: alpine→slim, add NODE_TLS_REJECT_UNAUTHORIZED=0, remove non-existent public/ COPY - web/next.config.ts: add transpilePackages + webpack symlinks for pnpm @bytelyst/* resolution Docker smoke tests: backend + web builds pass
40 lines
1.4 KiB
Docker
40 lines
1.4 KiB
Docker
# Pre-requisite: run ./scripts/docker-prep.sh to pack @bytelyst/* tarballs
|
|
# ── Stage 1: Build ────────────────────────────────────
|
|
FROM node:22-slim AS builder
|
|
WORKDIR /app/backend
|
|
ENV NODE_TLS_REJECT_UNAUTHORIZED=0
|
|
|
|
RUN npm config set strict-ssl false
|
|
COPY backend/package.json ./package.json
|
|
COPY backend/.docker-deps/ ./.docker-deps/
|
|
RUN npm install
|
|
|
|
COPY backend/tsconfig.json ./tsconfig.json
|
|
COPY backend/src/ ./src/
|
|
COPY shared/ ./shared/
|
|
RUN npm run build
|
|
|
|
# ── Stage 2: Runtime ──────────────────────────────────
|
|
FROM node:22-slim AS deps
|
|
WORKDIR /app/backend
|
|
ENV NODE_ENV=production
|
|
ENV NODE_TLS_REJECT_UNAUTHORIZED=0
|
|
|
|
RUN npm config set strict-ssl false
|
|
COPY backend/package.json ./package.json
|
|
COPY backend/.docker-deps/ ./.docker-deps/
|
|
RUN npm install --omit=dev --ignore-scripts
|
|
|
|
# ── Stage 3: Runtime ──────────────────────────────────
|
|
FROM node:22-slim
|
|
WORKDIR /app/backend
|
|
ENV NODE_ENV=production
|
|
|
|
COPY --from=deps /app/backend/node_modules ./node_modules
|
|
COPY --from=deps /app/backend/package.json ./package.json
|
|
COPY --from=builder /app/backend/dist ./dist
|
|
COPY shared/product.json ../shared/product.json
|
|
|
|
EXPOSE 4016
|
|
CMD ["node", "dist/server.js"]
|