CityGame/apps/frontend/Dockerfile
Camille 7a9383e87f feat: bootstrap fullstack NX monorepo (Spring Boot + React)
- Add Spring Boot 3.4 backend with health API, CORS, and dev/prod profiles
- Add React 18 + Vite frontend with typed health client
- Configure NX workspace, pnpm, and Docker Compose stacks
- Document stack, commands, and layout in README
- Add .gitignore for Node, Java, Docker, and IDE artifacts
2026-05-29 23:42:03 +02:00

38 lines
1 KiB
Docker

# Stage 1: Build
FROM node:20-alpine AS builder
# Enable pnpm via corepack
RUN corepack enable && corepack prepare pnpm@latest --activate
WORKDIR /workspace
# Copy workspace manifests first for dependency caching
COPY package.json pnpm-workspace.yaml pnpm-lock.yaml nx.json tsconfig.base.json ./
# Copy frontend app files
COPY apps/frontend ./apps/frontend
# Install all dependencies (frozen for reproducibility)
RUN pnpm install --frozen-lockfile
# Build the frontend
RUN pnpm nx run frontend:build --configuration=production
# Stage 2: Serve with nginx
FROM nginx:1.27-alpine AS runner
# Copy built assets
COPY --from=builder /workspace/dist/apps/frontend /usr/share/nginx/html
# Copy nginx config
COPY apps/frontend/nginx.conf /etc/nginx/conf.d/default.conf
# Create non-root user
RUN addgroup -S citygame && adduser -S citygame -G citygame
EXPOSE 80
HEALTHCHECK --interval=30s --timeout=5s --start-period=10s --retries=3 \
CMD wget -qO- http://localhost:80/healthz || exit 1
CMD ["nginx", "-g", "daemon off;"]