# Используем официальный Node.js образ FROM node:18-alpine AS base # Устанавливаем зависимости только когда нужно FROM base AS deps WORKDIR /app # Устанавливаем зависимости на основе предпочтительного менеджера пакетов COPY package.json package-lock.json* ./ RUN \ if [ -f package-lock.json ]; then npm ci; \ else echo "Lockfile not found." && exit 1; \ fi # Собираем исходный код только когда нужно FROM base AS builder WORKDIR /app COPY --from=deps /app/node_modules ./node_modules COPY . . # Генерируем Prisma клиент RUN npx prisma generate # Собираем приложение RUN npm run build # Удаляем dev зависимости для production RUN npm prune --production # Продакшн образ, копируем все файлы и запускаем next FROM base AS runner WORKDIR /app ENV NODE_ENV production # Отключаем телеметрию next.js во время runtime ENV NEXT_TELEMETRY_DISABLED 1 # Устанавливаем wget для healthcheck RUN apk add --no-cache wget RUN addgroup --system --gid 1001 nodejs RUN adduser --system --uid 1001 nextjs COPY --from=builder /app/public ./public # Автоматически использовать output traces для уменьшения размера образа # https://nextjs.org/docs/advanced-features/output-file-tracing COPY --from=builder --chown=nextjs:nodejs /app/.next/standalone ./ COPY --from=builder --chown=nextjs:nodejs /app/.next/static ./.next/static # Копируем Prisma схему и клиент для runtime COPY --from=builder --chown=nextjs:nodejs /app/prisma ./prisma COPY --from=builder --chown=nextjs:nodejs /app/node_modules/.prisma ./node_modules/.prisma COPY --from=builder --chown=nextjs:nodejs /app/node_modules/@prisma ./node_modules/@prisma USER nextjs EXPOSE 3000 ENV PORT 3000 ENV HOSTNAME "0.0.0.0" CMD ["node", "server.js"]