From 3beeb24b1ee4cdee88a20c4dcae04e1ffdad03f9 Mon Sep 17 00:00:00 2001 From: Patrick 'Lampe' Lamprecht Date: Mon, 10 Jun 2024 20:27:23 +0200 Subject: [PATCH] fix: Docker image not working (#753) * fix: Docker image not working * Update docker.yml * chore: update REGISTRY_IMAGE environment variable in Docker workflow * feat: update REGISTRY_IMAGE environment variable in Docker workflow * chore: lowercase REGISTRY_IMAGE for docker image naming convention * chore: update REGISTRY_IMAGE environment variable in Docker workflow * chore: update REGISTRY_IMAGE environment variable in Docker workflow * chore: update REGISTRY_IMAGE environment variable in Docker workflow * chore: update REGISTRY_IMAGE environment variable in Docker workflow * chore: update REGISTRY_IMAGE environment variable in Docker workflow * fix: Docker image not working --- .dockerignore | 34 +++++++++++++++++++++++++++++++ Dockerfile | 39 ++++++++++++++++++++++++++++------- compose.yaml | 51 ++++++++++++++++++++++++++++++++++++++++++++++ docs/changelog.rst | 2 ++ 4 files changed, 119 insertions(+), 7 deletions(-) create mode 100644 compose.yaml diff --git a/.dockerignore b/.dockerignore index 698bf237..cf758b5b 100644 --- a/.dockerignore +++ b/.dockerignore @@ -1,4 +1,38 @@ +# Include any files or directories that you don't want to be copied to your +# container here (e.g., local build artifacts, temporary files, etc.). +# +# For more help, visit the .dockerignore file reference guide at +# https://docs.docker.com/go/build-context-dockerignore/ + npm-debug.log *.pem .env coverage +**/.classpath +**/.dockerignore +**/.env +**/.git +**/.gitignore +**/.project +**/.settings +**/.toolstarget +**/.vs +**/.vscode +**/.next +**/.cache +**/*.*proj.user +**/*.dbmdl +**/*.jfm +**/charts +**/docker-compose* +**/compose.y*ml +**/Dockerfile* +**/node_modules +**/npm-debug.log +**/obj +**/secrets.dev.yaml +**/values.dev.yaml +**/build +**/dist +LICENSE +README.md diff --git a/Dockerfile b/Dockerfile index db493880..5201990c 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,13 +1,38 @@ -FROM node:16 +# syntax=docker/dockerfile:1 -WORKDIR /app +# Comments are provided throughout this file to help you get started. +# If you need more help, visit the Dockerfile reference guide at +# https://docs.docker.com/go/dockerfile-reference/ -COPY package*.json ./ -RUN npm ci --only=production +# Want to help us make this template better? Share your feedback here: https://forms.gle/ybq9Krt8jtBL3iCk7 +ARG NODE_VERSION=18 + +FROM node:${NODE_VERSION}-alpine + +# Use production node environment by default. +ENV NODE_ENV production + + +WORKDIR /usr/src/app + +# Download dependencies as a separate step to take advantage of Docker's caching. +# Leverage a cache mount to /root/.npm to speed up subsequent builds. +# Leverage a bind mounts to package.json and package-lock.json to avoid having to copy them into +# into this layer. +RUN --mount=type=bind,source=package.json,target=package.json \ + --mount=type=bind,source=package-lock.json,target=package-lock.json \ + --mount=type=cache,target=/root/.npm \ + npm ci --omit=dev + +# Run the application as a non-root user. +USER node + +# Copy the rest of the source files into the image. COPY . . -ENV PORT=${PORT:-3000} -USER 1000:1000 +# Expose the port that the application listens on. +EXPOSE 3000 -CMD ./node_modules/probot/bin/probot.js run --port $PORT ./index.js +# Run the application. +CMD npm start diff --git a/compose.yaml b/compose.yaml new file mode 100644 index 00000000..416d6c7d --- /dev/null +++ b/compose.yaml @@ -0,0 +1,51 @@ +# Comments are provided throughout this file to help you get started. +# If you need more help, visit the Docker Compose reference guide at +# https://docs.docker.com/go/compose-spec-reference/ + +# Here the instructions define your application as a service called "server". +# This service is built from the Dockerfile in the current directory. +# You can add other services your application may depend on here, such as a +# database or a cache. For examples, see the Awesome Compose repository: +# https://github.com/docker/awesome-compose +services: + server: + build: + context: . + environment: + NODE_ENV: production + ports: + - 3000:3000 + +# The commented out section below is an example of how to define a PostgreSQL +# database that your application can use. `depends_on` tells Docker Compose to +# start the database before your application. The `db-data` volume persists the +# database data between container restarts. The `db-password` secret is used +# to set the database password. You must create `db/password.txt` and add +# a password of your choosing to it before running `docker-compose up`. +# depends_on: +# db: +# condition: service_healthy +# db: +# image: postgres +# restart: always +# user: postgres +# secrets: +# - db-password +# volumes: +# - db-data:/var/lib/postgresql/data +# environment: +# - POSTGRES_DB=example +# - POSTGRES_PASSWORD_FILE=/run/secrets/db-password +# expose: +# - 5432 +# healthcheck: +# test: [ "CMD", "pg_isready" ] +# interval: 10s +# timeout: 5s +# retries: 5 +# volumes: +# db-data: +# secrets: +# db-password: +# file: db/password.txt + diff --git a/docs/changelog.rst b/docs/changelog.rst index 7f9f930c..8f4b7902 100644 --- a/docs/changelog.rst +++ b/docs/changelog.rst @@ -1,5 +1,7 @@ CHANGELOG ===================================== +| June 10, 2024: fix: Docker image not working `#753 `_ +| June 10, 2024: feat: publish multi arch docker image to dockerhub `#751 `_ | April 29, 2024: fix: Always allow assigning author `#744 `_ | Mar 11, 2024: fix: bump dependencies probot, jest and nock to latest versions and update ci workflow to use node 20 `#738 `_ | Feb 27, 2024: fix: search and replace of special annotations `#735 `_