# Используем официальный Node.js образ FROM node:18-alpine AS base # Устанавливаем зависимости только когда нужно FROM base AS deps # Проверяем https://github.com/nodejs/docker-node/tree/b4117f9333da4138b03a546ec926ef50a31506c3#nodealpine чтобы понять зачем нужен libc6-compat RUN apk add --no-cache libc6-compat 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 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"]