Merge pull request #746 from automatisch/separate-dockerfile-for-release

Separate dockerfile for release
This commit is contained in:
Ömer Faruk Aydın
2022-11-27 23:08:38 +01:00
committed by GitHub
7 changed files with 38 additions and 45 deletions

View File

@@ -3,7 +3,8 @@ services:
main:
build:
context: ./docker
image: automatischio/automatisch
dockerfile: Dockerfile.compose
entrypoint: /compose-entrypoint.sh
ports:
- '3000:3000'
depends_on:
@@ -28,7 +29,8 @@ services:
worker:
build:
context: ./docker
image: automatischio/automatisch
dockerfile: Dockerfile.compose
entrypoint: /compose-entrypoint.sh
depends_on:
- main
environment:
@@ -52,7 +54,7 @@ services:
volumes:
- postgres_data:/var/lib/postgresql/data
healthcheck:
test: ["CMD-SHELL", "pg_isready -U $${POSTGRES_USER} -d $${POSTGRES_DB}"]
test: ['CMD-SHELL', 'pg_isready -U $${POSTGRES_USER} -d $${POSTGRES_DB}']
interval: 10s
timeout: 5s
retries: 5

View File

@@ -1,18 +1,10 @@
# syntax=docker/dockerfile:1
FROM alpine
COPY ./entrypoint.sh /entrypoint.sh
RUN apk add --no-cache dos2unix && \
dos2unix /entrypoint.sh
FROM node:16-alpine
WORKDIR /automatisch
COPY --from=0 /entrypoint.sh /entrypoint.sh
COPY ./entrypoint.sh /entrypoint.sh
RUN apk add --no-cache openssl && yarn global add @automatisch/cli@0.2.0
RUN yarn global add @automatisch/cli@0.2.0
EXPOSE 3000
ENTRYPOINT ["sh", "/entrypoint.sh"]

11
docker/Dockerfile.compose Normal file
View File

@@ -0,0 +1,11 @@
# syntax=docker/dockerfile:1
FROM automatischio/automatisch:0.2.0
WORKDIR /automatisch
RUN apk add --no-cache openssl dos2unix
COPY ./compose-entrypoint.sh /compose-entrypoint.sh
RUN dos2unix /compose-entrypoint.sh
EXPOSE 3000
ENTRYPOINT ["sh", "/compose-entrypoint.sh"]

18
docker/compose-entrypoint.sh Executable file
View File

@@ -0,0 +1,18 @@
#!/bin/sh
set -e
if [ ! -f /automatisch/storage/.env ]; then
>&2 echo "Saving environment variables"
ENCRYPTION_KEY="${ENCRYPTION_KEY:-$(openssl rand -base64 36)}"
APP_SECRET_KEY="${APP_SECRET_KEY:-$(openssl rand -base64 36)}"
echo "ENCRYPTION_KEY=$ENCRYPTION_KEY" >> /automatisch/storage/.env
echo "APP_SECRET_KEY=$APP_SECRET_KEY" >> /automatisch/storage/.env
fi
# initiate env. vars. from /automatisch/storage/.env file
export $(grep -v '^#' /automatisch/storage/.env | xargs)
echo "Environment variables have been set!"
sh /entrypoint.sh

View File

@@ -2,16 +2,8 @@
set -e
if [ ! -f /automatisch/storage/.env ]; then
>&2 echo "Saving environment variables"
ENCRYPTION_KEY="${ENCRYPTION_KEY:-$(openssl rand -base64 36)}"
APP_SECRET_KEY="${APP_SECRET_KEY:-$(openssl rand -base64 36)}"
echo "ENCRYPTION_KEY=$ENCRYPTION_KEY" >> /automatisch/storage/.env
echo "APP_SECRET_KEY=$APP_SECRET_KEY" >> /automatisch/storage/.env
fi
if [ -n "$WORKER" ]; then
automatisch start-worker --env-file /automatisch/storage/.env
automatisch start-worker
else
automatisch start --env-file /automatisch/storage/.env
automatisch start
fi

View File

@@ -1,11 +0,0 @@
#!/bin/sh
set -e
until psql -h "$POSTGRES_HOST" -U "$POSTGRES_USERNAME" -d "$POSTGRES_DATABASE" -c '\q'; do
>&2 echo "Waiting for Postgres to be ready..."
sleep 1
done
>&2 echo "Postgres is up - executing command"
exec "$@"

View File

@@ -1,11 +0,0 @@
#!/bin/sh
set -e
until psql -h "$POSTGRES_HOST" -U "$POSTGRES_USERNAME" -d "$POSTGRES_DATABASE" -c '\q'; do
>&2 echo "Waiting for Postgres to be ready..."
sleep 1
done
>&2 echo "Postgres is up - executing command"
exec "$@"