2025-10-21 09:29:35 +09:00
|
|
|
# Base image (WACE Docker Hub)
|
|
|
|
|
FROM dockerhub.wace.me/node:20.19-alpine.linux AS base
|
2025-08-22 15:45:05 +09:00
|
|
|
WORKDIR /app
|
|
|
|
|
ENV NODE_ENV=production
|
2025-08-28 15:24:00 +09:00
|
|
|
# Install OpenSSL, curl (for healthcheck), and required certs
|
2025-10-21 09:29:35 +09:00
|
|
|
RUN apk add --no-cache openssl ca-certificates curl
|
2025-08-22 15:45:05 +09:00
|
|
|
|
2025-10-01 15:11:07 +09:00
|
|
|
# Dependencies stage (install production dependencies)
|
2025-08-22 15:45:05 +09:00
|
|
|
FROM base AS deps
|
|
|
|
|
COPY package*.json ./
|
2025-08-28 11:27:15 +09:00
|
|
|
RUN npm ci --omit=dev --prefer-offline --no-audit && npm cache clean --force
|
2025-08-22 15:45:05 +09:00
|
|
|
|
|
|
|
|
# Build stage (compile TypeScript)
|
2025-10-21 09:29:35 +09:00
|
|
|
FROM dockerhub.wace.me/node:20.19-alpine.linux AS build
|
2025-08-22 15:45:05 +09:00
|
|
|
WORKDIR /app
|
|
|
|
|
COPY package*.json ./
|
2025-08-28 11:27:15 +09:00
|
|
|
RUN npm ci --prefer-offline --no-audit && npm cache clean --force
|
2025-08-22 15:45:05 +09:00
|
|
|
COPY tsconfig.json ./
|
|
|
|
|
COPY src ./src
|
|
|
|
|
RUN npm run build
|
|
|
|
|
|
2025-08-28 11:27:15 +09:00
|
|
|
# Runtime image - base 이미지 재사용으로 중복 설치 제거
|
|
|
|
|
FROM base AS runner
|
2025-08-22 15:45:05 +09:00
|
|
|
ENV NODE_ENV=production
|
|
|
|
|
|
|
|
|
|
# Create non-root user
|
|
|
|
|
RUN groupadd -r appgroup && useradd -r -g appgroup appuser
|
|
|
|
|
|
2025-10-01 15:11:07 +09:00
|
|
|
# Copy production node_modules
|
2025-08-22 15:45:05 +09:00
|
|
|
COPY --from=deps /app/node_modules ./node_modules
|
|
|
|
|
# Copy built files
|
|
|
|
|
COPY --from=build /app/dist ./dist
|
|
|
|
|
# Copy package files
|
|
|
|
|
COPY package*.json ./
|
|
|
|
|
|
2025-10-16 10:33:21 +09:00
|
|
|
# 루트 디렉토리만 생성하고 appuser에게 쓰기 권한 부여
|
|
|
|
|
# 하위 디렉토리는 애플리케이션이 런타임에 자동 생성
|
|
|
|
|
RUN mkdir -p logs uploads data && \
|
|
|
|
|
chown -R appuser:appgroup /app && \
|
|
|
|
|
chmod -R 755 /app
|
2025-08-25 17:24:43 +09:00
|
|
|
|
2025-08-22 15:45:05 +09:00
|
|
|
EXPOSE 8080
|
|
|
|
|
USER appuser
|
|
|
|
|
CMD ["node", "dist/app.js"]
|