# Многоступенчатая сборка для оптимизации размера образа # Стадия 1: Установка зависимостей FROM node:18-alpine AS deps RUN apk add --no-cache libc6-compat WORKDIR /app # Копируем файлы зависимостей COPY nextjs_space/package.json nextjs_space/yarn.lock* ./ RUN yarn install --frozen-lockfile --production=false # Стадия 2: Сборка приложения FROM node:18-alpine AS builder WORKDIR /app # Копируем зависимости из предыдущей стадии COPY --from=deps /app/node_modules ./node_modules COPY nextjs_space/ ./ # Используем production конфигурацию RUN mv next.config.prod.js next.config.js || true # Создаем .env файл для сборки ARG NEXT_PUBLIC_SITE_URL ENV NEXT_PUBLIC_SITE_URL=${NEXT_PUBLIC_SITE_URL} # Собираем приложение RUN yarn build # Стадия 3: Production образ FROM node:18-alpine AS runner WORKDIR /app ENV NODE_ENV=production ENV NEXT_TELEMETRY_DISABLED=1 # Создаем пользователя для безопасности RUN addgroup --system --gid 1001 nodejs RUN adduser --system --uid 1001 nextjs # Копируем необходимые файлы COPY --from=builder /app/public ./public COPY --from=builder /app/.next/standalone ./ COPY --from=builder /app/.next/static ./.next/static # Устанавливаем правильные права RUN chown -R nextjs:nodejs /app USER nextjs EXPOSE 3000 ENV PORT=3000 ENV HOSTNAME="0.0.0.0" # Запускаем приложение CMD ["node", "server.js"]