From 8b4ea8b3c557dfc9a8eb870a14bfff528b0f3395 Mon Sep 17 00:00:00 2001 From: Liam <67254223+RealFascinated@users.noreply.github.com> Date: Wed, 26 Oct 2022 12:15:56 +0100 Subject: [PATCH] Add Dockerfile and docker-compose.yml --- .drone.yml | 12 ++++++---- Dockerfile | 57 ++++++++++++++++++++++++++++++++++++++++++++++ docker-compose.yml | 15 ++++++++++++ 3 files changed, 79 insertions(+), 5 deletions(-) create mode 100644 Dockerfile create mode 100644 docker-compose.yml diff --git a/.drone.yml b/.drone.yml index bb05a40..f0b95ee 100644 --- a/.drone.yml +++ b/.drone.yml @@ -16,8 +16,10 @@ steps: image: node:18-alpine commands: - npm run build - - name: deploy - image: node:18-alpine - detach: true - commands: - - npm run start + - name: docker + image: plugins/docker + settings: + username: from_secret: dockerhub_username + password: from_secret: dockerhub_password + repo: fascinated/beatsaber-overlay + tags: latest \ No newline at end of file diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 0000000..a97abaa --- /dev/null +++ b/Dockerfile @@ -0,0 +1,57 @@ +# Install dependencies only when needed +FROM node:18-alpine AS deps +# Check https://github.com/nodejs/docker-node/tree/b4117f9333da4138b03a546ec926ef50a31506c3#nodealpine to understand why libc6-compat might be needed. +RUN apk add --no-cache libc6-compat +WORKDIR /app + +# Install dependencies based on the preferred package manager +COPY package.json yarn.lock* package-lock.json* pnpm-lock.yaml* ./ +RUN \ + if [ -f yarn.lock ]; then yarn --frozen-lockfile; \ + elif [ -f package-lock.json ]; then npm ci; \ + elif [ -f pnpm-lock.yaml ]; then yarn global add pnpm && pnpm i --frozen-lockfile; \ + else echo "Lockfile not found." && exit 1; \ + fi + + +# Rebuild the source code only when needed +FROM node:16-alpine AS builder +WORKDIR /app +COPY --from=deps /app/node_modules ./node_modules +COPY . . + +# Next.js collects completely anonymous telemetry data about general usage. +# Learn more here: https://nextjs.org/telemetry +# Uncomment the following line in case you want to disable telemetry during the build. +# ENV NEXT_TELEMETRY_DISABLED 1 + +RUN yarn build + +# If using npm comment out above and use below instead +# RUN npm run build + +# Production image, copy all the files and run next +FROM node:16-alpine AS runner +WORKDIR /app + +ENV NODE_ENV production +# Uncomment the following line in case you want to disable telemetry during runtime. +# ENV NEXT_TELEMETRY_DISABLED 1 + +RUN addgroup --system --gid 1001 nodejs +RUN adduser --system --uid 1001 nextjs + +COPY --from=builder /app/public ./public + +# Automatically leverage output traces to reduce image size +# https://nextjs.org/docs/advanced-features/output-file-tracing +COPY --from=builder --chown=nextjs:nodejs /app/.next/standalone ./ +COPY --from=builder --chown=nextjs:nodejs /app/.next/static ./.next/static + +USER nextjs + +EXPOSE 3000 + +ENV PORT 3000 + +CMD ["node", "server.js"] \ No newline at end of file diff --git a/docker-compose.yml b/docker-compose.yml new file mode 100644 index 0000000..5ef63fd --- /dev/null +++ b/docker-compose.yml @@ -0,0 +1,15 @@ +services: + beatsaber-overlay: + image: fascinated/beatsaber-overlay:latest + env_file: + - .env.production + ports: + - 3000:3000 + depends_on: + - redis + + redis: + image: bitnami/redis:latest + environment: + - REDIS_PASSWORD= + command: /opt/bitnami/scripts/redis/run.sh --maxmemory 512mb