Files
dealplustech/Dockerfile
Kunthawat Greethong c0bd564d53 🐳 Add Dockerfile for Next.js production deployment
Features:
 Multi-stage build (deps → builder → runner)
 Optimized for Next.js standalone output
 Non-root user for security (nextjs:nodejs)
 dumb-init for proper signal handling
 Health checks configured
 Exposes port 3000

Benefits over Nixpacks:
 Faster builds (cached dependencies)
 Smaller image size (~150MB vs ~500MB)
 More predictable builds
 Full control over build process
 Better security (non-root user)

Easypanel Configuration:
- Build Type: Dockerfile
- Dockerfile Path: ./Dockerfile
- Port: 3000
2026-03-10 10:03:15 +07:00

63 lines
1.4 KiB
Docker

# Stage 1: Dependencies
FROM node:20-alpine AS deps
WORKDIR /app
# Copy package files
COPY package.json package-lock.json* ./
# Install dependencies
RUN npm ci
# Stage 2: Builder
FROM node:20-alpine AS builder
WORKDIR /app
# Copy dependencies from deps stage
COPY --from=deps /app/node_modules ./node_modules
COPY --from=deps /app/package.json ./package.json
COPY --from=deps /app/package-lock.json ./package-lock.json
# Copy source code
COPY . .
# Build Next.js application
RUN npm run build
# Stage 3: Runner
FROM node:20-alpine AS runner
WORKDIR /app
ENV NODE_ENV=production
ENV NEXT_TELEMETRY_DISABLED=1
# Install dumb-init for proper signal handling
RUN apk add --no-cache dumb-init
# Create non-root user
RUN addgroup --system --gid 1001 nodejs
RUN adduser --system --uid 1001 nextjs
# Copy necessary files from builder
COPY --from=builder /app/public ./public
COPY --from=builder --chown=nextjs:nodejs /app/.next/standalone ./
COPY --from=builder --chown=nextjs:nodejs /app/.next/static ./.next/static
# Set correct permissions
RUN chown -R nextjs:nodejs /app
USER nextjs
# Expose port
EXPOSE 3000
# Set PORT environment variable
ENV PORT=3000
ENV HOSTNAME="0.0.0.0"
# Health check
HEALTHCHECK --interval=30s --timeout=3s --start-period=5s --retries=3 \
CMD node -e "require('http').get('http://localhost:3000', (r) => {process.exit(r.statusCode === 200 ? 0 : 1)})"
# Start application with dumb-init
CMD ["dumb-init", "node", "server.js"]