Skip to content

Commit

Permalink
Dockerizing the image of codebase and Establishing CI/CD pipeline
Browse files Browse the repository at this point in the history
  - The image is a multi-stage build
  - The docker-compose file is also included
  - The containerization requires a bit of configuration
    because there NextAuth issue and trustHost: true
    as a workaround
  - The CI/CD pipeline is established using Github Actions
    and the workflow is defined in the build.yaml file
  • Loading branch information
AlexiusTatius committed Jan 2, 2025
1 parent 2b1710c commit 8fb746a
Show file tree
Hide file tree
Showing 8 changed files with 557 additions and 1 deletion.
68 changes: 68 additions & 0 deletions .dockerignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,68 @@
# Dependencies
node_modules
.pnpm-store
.npm
npm-debug.log*
yarn-debug.log*
yarn-error.log*

# Testing
/coverage
*.test.js
*.spec.js

# Next.js
.next
out

# Production
/build

# Misc
.DS_Store
*.pem
.env.local
.env.development.local
.env.test.local
.env.production.local

# Debug
npm-debug.log*
yarn-debug.log*
yarn-error.log*
.pnpm-debug.log*

# IDEs and editors
.idea
.vscode
*.swp
*.swo
*.swn
*.bak

# Version control
.git
.gitignore
.gitattributes
.github

# Project specific
README.md
CHANGELOG.md
contributing.md
LICENSE
ProjectInfo/
*.md
!next.config.mjs

# Docker
Dockerfile
.dockerignore
docker-compose*

# Other
.husky
.eslintrc
.prettierrc
.prettierignore
*.log
48 changes: 48 additions & 0 deletions .github/workflows/build.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
name: Build and Push Docker Image

on:
push:
branches: ["master"]
pull_request:
branches: ["master"]
workflow_dispatch: # Allows you to run this workflow manually

jobs:
build-and-push:
runs-on: ubuntu-latest

steps:
# Step 1: Check out the repository code
- name: Checkout code
uses: actions/checkout@v3

# Step 2: Set up Docker Buildx (allows multi-platform builds and advanced features)
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2

# Step 3: Log in to Docker Hub using GitHub Secrets
- name: Log in to Docker Hub
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}

# Step 4: Build and push the Docker image
- name: Build and Push Docker Image
uses: docker/build-push-action@v4
with:
# Path to your Dockerfile context (the directory containing Dockerfile)
context: .
# Explicitly specify the Dockerfile if it's not in the root
file: ./Dockerfile
# The image(s) to push. Replace "YOUR_DOCKERHUB_USERNAME" and "YOUR_IMAGE_NAME".
# You can add multiple tags, for example, "latest" and one that references the commit SHA.
tags: |
${{ secrets.DOCKERHUB_USERNAME }}/YOUR_IMAGE_NAME:latest
${{ secrets.DOCKERHUB_USERNAME }}/YOUR_IMAGE_NAME:${{ github.sha }}
push: true
# (Optional) If you want multi-platform images, e.g., for amd64 & arm64, add:
# platforms: linux/amd64,linux/arm64

# Optional: If you want to confirm the image was successfully built/pushed,
# you can add steps such as "docker pull" or other testing steps here.
10 changes: 9 additions & 1 deletion app/api/auth/[...nextauth]/route.js
Original file line number Diff line number Diff line change
@@ -1 +1,9 @@
export { GET, POST } from "@/auth";
import NextAuth from "next-auth";

const handler = NextAuth({
providers: [], // No external providers
secret: process.env.AUTH_SECRET, // Required even in development
trustHost: true, // Set to true for development mode
});

export { handler as GET, handler as POST };
34 changes: 34 additions & 0 deletions docker-compose.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
version: "3.8"

services:
nextjs:
# This uses either a pre-built image (if IMAGE_NAME is defined)
# or builds locally using the Dockerfile if IMAGE_NAME is unset
image: ${IMAGE_NAME:-}
build: .
container_name: nextjs
ports:
- "3000:3000"
environment:
- AUTH_SECRET=${AUTH_SECRET}
- NEXTAUTH_URL=${NEXTAUTH_URL}
- NEXTAUTH_TRUST_HOST=${NEXTAUTH_TRUST_HOST}
- AUTH_SECRET=${AUTH_SECRET}
- MONGODB_URI=${MONGODB_URI}
- HOST_URL=${HOST_URL}
- NEXT_PUBLIC_BACKEND_URL=${NEXT_PUBLIC_BACKEND_URL}

restart: unless-stopped
healthcheck:
test:
[
"CMD",
"wget",
"--no-verbose",
"--tries=1",
"--spider",
"http://localhost:3000",
]
interval: 30s
timeout: 10s
retries: 3
52 changes: 52 additions & 0 deletions dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
# Stage 1: Dependencies
FROM node:18-alpine AS deps
RUN corepack enable && corepack prepare pnpm@latest --activate

WORKDIR /app
COPY package.json pnpm-lock.yaml ./
# Make sure sharp is in your package.json if you need image optimization
RUN pnpm install --frozen-lockfile

# Stage 2: Builder
FROM node:18-alpine AS builder
RUN corepack enable && corepack prepare pnpm@latest --activate

WORKDIR /app
COPY --from=deps /app/node_modules ./node_modules
COPY . .

# Build the Next.js application (standalone mode)
RUN pnpm build

# Stage 3: Runner
FROM node:18-alpine AS runner
RUN corepack enable && corepack prepare pnpm@latest --activate

WORKDIR /app

ENV NODE_ENV=production

# Create a non-root user and group
RUN addgroup --system --gid 1001 nodejs
RUN adduser --system --uid 1001 nextjs

# Copy only the necessary files from the builder stage
COPY --from=builder /app/public ./public
COPY --from=builder /app/.next/standalone ./
COPY --from=builder /app/.next/static ./.next/static

# -- Create and set permissions for the cache directory --
# Although standalone mode might not always strictly need it,
# Next.js at runtime may still try to access .next/cache
RUN mkdir -p .next/cache && chown -R nextjs:nodejs .next

# Switch to the non-root user
USER nextjs

# Expose the port
EXPOSE 3000
ENV PORT=3000
ENV HOSTNAME="0.0.0.0"

# Command to start the application
CMD ["node", "server.js"]
1 change: 1 addition & 0 deletions next.config.mjs
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
/** @type {import('next').NextConfig} */
const nextConfig = {
output: "standalone",
images: {
remotePatterns: [
{
Expand Down
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@
"react-dom": "^18",
"react-redux": "^9.1.0",
"react-spinners": "^0.13.8",
"sharp": "^0.33.5",
"socket.io-client": "^4.7.5",
"sonner": "^1.4.41",
"tailwind-merge": "^2.4.0",
Expand Down
Loading

0 comments on commit 8fb746a

Please sign in to comment.