From 91087013c9add9cd5c2df6de6732b4b82793a40e Mon Sep 17 00:00:00 2001 From: Abhishek kushwaha Date: Fri, 5 Apr 2024 10:35:39 +0530 Subject: [PATCH] feat: web docker image optimisation Signed-off-by: Abhishek kushwaha --- apps/web/Dockerfile | 57 +++++++++++++++++++++++++++++++---------- apps/web/next.config.js | 1 + docker-compose-test.yml | 21 ++++++++++++++- docker-compose.yml | 20 +++++++++++++++ 4 files changed, 85 insertions(+), 14 deletions(-) diff --git a/apps/web/Dockerfile b/apps/web/Dockerfile index 2c8ec2ae..38e34aa1 100644 --- a/apps/web/Dockerfile +++ b/apps/web/Dockerfile @@ -1,24 +1,55 @@ -FROM node:20-alpine AS build +FROM node:20-alpine AS base + +FROM base AS builder +RUN apk add --no-cache libc6-compat +RUN apk update +# working directory WORKDIR /app +RUN npm install -g turbo +COPY . . +RUN turbo prune web --docker -RUN npm i -g pnpm +# Add lockfile and package.json's of isolated subworkspace +FROM base AS installer +RUN apk add --no-cache libc6-compat +RUN apk update +WORKDIR /app -# COPY package.json . -COPY turbo.json . -COPY pnpm-workspace.yaml . -COPY package*.json . -COPY ./packages ./packages +# install the dependencies +RUN npm install -g pnpm +COPY .gitignore .gitignore +COPY --from=builder /app/out/json/ . +COPY --from=builder /app/out/pnpm-lock.yaml ./pnpm-lock.yaml +RUN pnpm install -COPY apps/web/package.json apps/web/package.json -COPY apps/web/tsconfig.json apps/web/tsconfig.json +# Build the project +COPY --from=builder /app/out/full/ . +COPY turbo.json turbo.json -RUN pnpm install -COPY . . +RUN pnpm turbo build --filter=web... -RUN pnpm run build:web +FROM base AS runner +WORKDIR /app +# Don't run production as root +RUN addgroup --system --gid 1001 nodejs +RUN adduser --system --uid 1001 nextjs +USER nextjs + +COPY --from=installer /app/apps/web/next.config.js . +COPY --from=installer /app/apps/web/package.json . + +# Automatically leverage output traces to reduce image size +# https://nextjs.org/docs/advanced-features/output-file-tracing +COPY --from=installer --chown=nextjs:nodejs /app/apps/web/.next/standalone ./ +COPY --from=installer --chown=nextjs:nodejs /app/apps/web/.next/static ./apps/web/.next/static +COPY --from=installer --chown=nextjs:nodejs /app/apps/web/public ./apps/web/public + +ENV PORT=3000 EXPOSE 3000 +ENV HOSTNAME "0.0.0.0" + -ENTRYPOINT ["pnpm", "run", "start:web"] \ No newline at end of file +CMD node apps/web/server.js \ No newline at end of file diff --git a/apps/web/next.config.js b/apps/web/next.config.js index 6631e2cc..eae1e08b 100644 --- a/apps/web/next.config.js +++ b/apps/web/next.config.js @@ -1,6 +1,7 @@ const path = require("node:path"); /** @type {import('next').NextConfig} */ const nextConfig = { + output: "standalone", webpack(config, { isServer }) { config.module.rules.push({ test: /\.svg$/, diff --git a/docker-compose-test.yml b/docker-compose-test.yml index 4c290a38..fd7205f8 100644 --- a/docker-compose-test.yml +++ b/docker-compose-test.yml @@ -15,7 +15,26 @@ services: POSTGRES_DB: tests networks: - keyshade-test - + web: + container_name: keyshade-web + build: + context: . + dockerfile: ./apps/web/Dockerfile + restart: always + ports: + - 3000:3000 + networks: + - keyshade-test + api: + container_name: keyshade-api + build: + context: . + dockerfile: ./apps/api/Dockerfile + restart: always + ports: + - 3001:3001 + networks: + - keyshade-test networks: keyshade-test: driver: bridge diff --git a/docker-compose.yml b/docker-compose.yml index 1b689832..9e8d7260 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -13,6 +13,26 @@ services: - ./data:/var/lib/postgresql/data networks: - keyshade-dev + web: + container_name: keyshade-web + build: + context: . + dockerfile: ./apps/web/Dockerfile + restart: always + ports: + - 3000:3000 + networks: + - keyshade-dev + api: + container_name: keyshade-api + build: + context: . + dockerfile: ./apps/api/Dockerfile + restart: always + ports: + - 3001:3001 + networks: + - keyshade-dev networks: keyshade-dev: