ERP-node/docker/prod/backend.Dockerfile

49 lines
1.4 KiB
Docker
Raw Normal View History

2025-10-20 18:08:03 +09:00
# syntax=docker/dockerfile:1
2025-08-22 15:45:05 +09:00
# Base image (Debian-based for glibc + OpenSSL compatibility)
FROM node:20-bookworm-slim AS base
WORKDIR /app
ENV NODE_ENV=production
2025-08-28 15:24:00 +09:00
# Install OpenSSL, curl (for healthcheck), and required certs
2025-08-22 15:45:05 +09:00
RUN apt-get update \
2025-08-28 15:24:00 +09:00
&& apt-get install -y --no-install-recommends openssl ca-certificates curl \
2025-08-22 15:45:05 +09:00
&& rm -rf /var/lib/apt/lists/*
# 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)
FROM node:20-bookworm-slim AS build
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
# 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"]