Files
lcbp3/backend/Dockerfile
admin b7676777e8
All checks were successful
Build and Deploy / deploy (push) Successful in 1m19s
fix(docker): replace pnpm deploy --legacy with --shamefully-hoist to fix ENOENT bin symlink error
2026-02-23 14:21:04 +07:00

83 lines
2.4 KiB
Docker

# ============================================================
# LCBP3 Backend — NestJS Production Dockerfile
# Multi-stage build: deps → build → production
# Target: QNAP TS-473A (Container Station)
# ============================================================
# Build context: workspace root (nap-dms.lcbp3/)
# Usage: docker build -f backend/Dockerfile -t lcbp3-backend:latest .
# ============================================================
# =========================
# Stage 1: Install Dependencies
# =========================
FROM node:22-alpine AS deps
RUN corepack enable && corepack prepare pnpm@latest --activate
WORKDIR /app
# Copy workspace root manifests
COPY package.json pnpm-lock.yaml pnpm-workspace.yaml ./
COPY backend/package.json ./backend/
# Install backend deps only using pnpm workspace filter
RUN pnpm install --frozen-lockfile --filter backend...
# =========================
# Stage 2: Build Application
# =========================
FROM node:22-alpine AS build
RUN corepack enable && corepack prepare pnpm@latest --activate
WORKDIR /app
# Copy workspace structure
COPY package.json pnpm-lock.yaml pnpm-workspace.yaml ./
COPY --from=deps /app/node_modules ./node_modules
COPY --from=deps /app/backend/node_modules ./backend/node_modules
# Copy backend source
COPY backend/ ./backend/
# Build NestJS → backend/dist
RUN cd backend && pnpm run build
# Deploy with production deps only (pnpm workspace isolation)
RUN pnpm --filter backend deploy --prod --shamefully-hoist /app/backend-prod
# =========================
# Stage 3: Production Runtime
# =========================
FROM node:22-alpine AS production
# Install curl for healthcheck
RUN apk add --no-cache curl
WORKDIR /app
ENV TZ=Asia/Bangkok
ENV NODE_ENV=production
# Create non-root user
RUN addgroup -g 1001 -S nestjs && \
adduser -S nestjs -u 1001
# Copy production artifacts only
COPY --from=build --chown=nestjs:nestjs /app/backend/dist ./dist
COPY --from=build --chown=nestjs:nestjs /app/backend-prod/node_modules ./node_modules
COPY --from=build --chown=nestjs:nestjs /app/backend-prod/package.json ./
# Create uploads directory (Two-Phase Storage)
RUN mkdir -p /app/uploads/temp /app/uploads/permanent && \
chown -R nestjs:nestjs /app/uploads
USER nestjs
EXPOSE 3000
HEALTHCHECK --interval=30s --timeout=10s --retries=3 --start-period=30s \
CMD curl -f http://localhost:3000/health || exit 1
CMD ["node", "dist/main"]