28 lines
1.1 KiB
Docker
28 lines
1.1 KiB
Docker
# 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;"]
|