# syntax=docker/dockerfile:1.7 FROM node:20-alpine AS deps WORKDIR /app COPY package.json package-lock.json* pnpm-lock.yaml* yarn.lock* ./ RUN \ if [ -f pnpm-lock.yaml ]; then corepack enable && pnpm i --frozen-lockfile; \ elif [ -f yarn.lock ]; then corepack enable && yarn install --frozen-lockfile; \ elif [ -f package-lock.json ]; then npm ci; \ else npm install; fi FROM node:20-alpine AS builder WORKDIR /app COPY --from=deps /app/node_modules ./node_modules COPY . . # 비-로컬호스트 환경(스테이징/IP 서버 등)에서도 /dev/* 와 /test 라우트를 노출. # Vite 의 loadEnv 는 .env 파일만 읽으므로 빌드 직전에 파일로 기록한다. # 운영 빌드에서 막으려면 --build-arg VITE_ENABLE_DEV_ROUTES=false 로 오버라이드. ARG VITE_ENABLE_DEV_ROUTES=true RUN echo "VITE_ENABLE_DEV_ROUTES=${VITE_ENABLE_DEV_ROUTES}" >> .env.production \ && npm run build FROM nginx:1.27-alpine AS runner COPY --from=builder /app/dist /usr/share/nginx/html COPY nginx.conf /etc/nginx/conf.d/default.conf EXPOSE 80 CMD ["nginx", "-g", "daemon off;"]