Merge pull request #1 from 1337beanz/deployment

Deployment
This commit is contained in:
Znmin
2025-12-19 23:34:09 +01:00
committed by GitHub
2 changed files with 58 additions and 0 deletions

42
Dockerfile Normal file
View File

@@ -0,0 +1,42 @@
# --- STAGE 1: Base build environment ---
FROM node:lts-alpine3.23 AS base
WORKDIR /app
COPY package.json package-lock.json ./
# Install necessary dependencies for sharp used by next/image (for image optimization)
RUN apk add --no-cache libc6-compat
# Install dependencies
RUN npm ci --legacy-peer-deps
COPY . .
# --- STAGE 2: Environments
# Development
FROM base AS development
ARG ENVIRONMENT=development
ENV NODE_ENV=$ENVIRONMENT
RUN addgroup -S appuser && adduser -S appuser -G appuser
RUN chown -R appuser:appuser /app
USER appuser
EXPOSE 3000
CMD ["npm", "run", "dev"]
# Production
FROM base AS build
ARG ENVIRONMENT=production
ENV NODE_ENV=$ENVIRONMENT
RUN npm run build
#--- STAGE 3: Production runtime environment
FROM node:lts-alpine3.23 AS production
WORKDIR /app
RUN addgroup -S appuser && adduser -S appuser -G appuser
COPY --from=build /app/.next ./.next
COPY --from=build /app/package.json ./package.json
COPY --from=build /app/package-lock.json ./package-lock.json
COPY --from=build /app/next.config.ts ./next.config.ts
COPY --from=build /app/public ./public
COPY --from=build /app/node_modules ./node_modules
RUN chown -R appuser:appuser /app
USER appuser
EXPOSE 3000
CMD ["npm", "run", "start"]

16
docker-compose.yml Normal file
View File

@@ -0,0 +1,16 @@
services:
gsh-website:
image: gsh-website:prod
container_name: gsh-website
build:
context: .
dockerfile: Dockerfile
restart: unless-stopped
ports:
- "4000:3000"
volumes:
- ./public/uploads:/app/public/uploads
environment:
- NODE_ENV=production
# Add additional Next.js runtime configuration below as needed, for example:
# - NEXT_PUBLIC_API_URL=https://api.example.com