mirror of
https://github.com/multica-ai/multica.git
synced 2026-06-17 03:38:32 +02:00
public/ is mode 750 locally, so COPY into the runner stage landed files as root and the nextjs user fell under other perms, causing EACCES on scandir at startup. Add --chown=nextjs:nodejs to the standalone/static/public COPYs.
70 lines
2.2 KiB
Docker
70 lines
2.2 KiB
Docker
# --- Dependencies ---
|
|
FROM node:22-alpine AS deps
|
|
|
|
RUN corepack enable && corepack prepare pnpm@10.28.2 --activate
|
|
|
|
WORKDIR /app
|
|
|
|
# Copy workspace config and all package.json files for dependency resolution
|
|
COPY pnpm-lock.yaml pnpm-workspace.yaml package.json turbo.json ./
|
|
COPY apps/web/package.json apps/web/
|
|
COPY packages/core/package.json packages/core/
|
|
COPY packages/ui/package.json packages/ui/
|
|
COPY packages/views/package.json packages/views/
|
|
COPY packages/tsconfig/package.json packages/tsconfig/
|
|
COPY packages/eslint-config/package.json packages/eslint-config/
|
|
|
|
RUN pnpm install --frozen-lockfile
|
|
|
|
# --- Build ---
|
|
FROM node:22-alpine AS builder
|
|
|
|
RUN corepack enable && corepack prepare pnpm@10.28.2 --activate
|
|
|
|
WORKDIR /app
|
|
|
|
COPY --from=deps /app/node_modules ./node_modules
|
|
COPY --from=deps /app/apps/web/node_modules ./apps/web/node_modules
|
|
COPY --from=deps /app/packages/core/node_modules ./packages/core/node_modules
|
|
COPY --from=deps /app/packages/ui/node_modules ./packages/ui/node_modules
|
|
COPY --from=deps /app/packages/views/node_modules ./packages/views/node_modules
|
|
COPY --from=deps /app/packages/eslint-config/node_modules ./packages/eslint-config/node_modules
|
|
|
|
# Copy source
|
|
COPY package.json turbo.json pnpm-workspace.yaml ./
|
|
COPY apps/web/ apps/web/
|
|
COPY packages/ packages/
|
|
|
|
# Set build-time env: tells Next.js rewrites to proxy API calls to the backend service
|
|
ARG REMOTE_API_URL=http://backend:8080
|
|
ENV REMOTE_API_URL=$REMOTE_API_URL
|
|
ENV STANDALONE=true
|
|
|
|
# Build the web app (standalone output for minimal runtime)
|
|
RUN pnpm --filter @multica/web build
|
|
|
|
# --- Runtime ---
|
|
FROM node:22-alpine AS runner
|
|
|
|
WORKDIR /app
|
|
|
|
ENV NODE_ENV=production
|
|
|
|
RUN addgroup --system --gid 1001 nodejs && \
|
|
adduser --system --uid 1001 nextjs
|
|
|
|
# Copy standalone output (includes traced node_modules)
|
|
COPY --from=builder --chown=nextjs:nodejs /app/apps/web/.next/standalone ./
|
|
# Copy static files (not included in standalone)
|
|
COPY --from=builder --chown=nextjs:nodejs /app/apps/web/.next/static ./apps/web/.next/static
|
|
# Copy public assets
|
|
COPY --from=builder --chown=nextjs:nodejs /app/apps/web/public ./apps/web/public
|
|
|
|
USER nextjs
|
|
|
|
EXPOSE 3000
|
|
ENV PORT=3000
|
|
ENV HOSTNAME=0.0.0.0
|
|
|
|
CMD ["node", "apps/web/server.js"]
|