From 6aad1c9250475c7b2d74e029a1f2db57268aad9d Mon Sep 17 00:00:00 2001 From: Mouse Reeve Date: Sun, 22 Mar 2020 11:21:19 -0700 Subject: [PATCH] Dockerize app --- .env.example | 19 ++++++++++++------- Dockerfile | 7 +++++++ docker-compose.yml | 19 +++++++++++++++++++ fedireads/settings.py | 26 ++++++++------------------ 4 files changed, 46 insertions(+), 25 deletions(-) create mode 100644 Dockerfile create mode 100644 docker-compose.yml diff --git a/.env.example b/.env.example index 9f3dd381..141dc376 100644 --- a/.env.example +++ b/.env.example @@ -1,18 +1,23 @@ # SECURITY WARNING: keep the secret key used in production secret! -export SECRET_KEY="7(2w1sedok=aznpq)ta1mc4i%4h=xx@hxwx*o57ctsuml0x%fr" +SECRET_KEY="7(2w1sedok=aznpq)ta1mc4i%4h=xx@hxwx*o57ctsuml0x%fr" # SECURITY WARNING: don't run with debug turned on in production! -export DEBUG=true +DEBUG=true -export DOMAIN=your.domain.here +DOMAIN=your.domain.here ## Leave unset to allow all hosts -# export ALLOWED_HOSTS="localhost,127.0.0.1,[::1]" +# ALLOWED_HOSTS="localhost,127.0.0.1,[::1]" -export OL_URL="https://openlibrary.org" +OL_URL="https://openlibrary.org" ## Database backend to use. ## Default is postgres, sqlite is for dev quickstart only (NOT production!!!) -export FEDIREADS_DATABASE_BACKEND=postgres +FEDIREADS_DATABASE_BACKEND=postgres + +MEDIA_ROOT="images/" + +POSTGRES_PASSWORD="fedireads" +POSTGRES_USER="postgres" +POSTGRES_DB="postgres" -export MEDIA_ROOT="images/" \ No newline at end of file diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 00000000..cd56e6ee --- /dev/null +++ b/Dockerfile @@ -0,0 +1,7 @@ +FROM python:3 +ENV PYTHONUNBUFFERED 1 +RUN mkdir /code +WORKDIR /code +COPY requirements.txt /code/ +RUN pip install -r requirements.txt +COPY ./fedireads /code diff --git a/docker-compose.yml b/docker-compose.yml new file mode 100644 index 00000000..9545ef94 --- /dev/null +++ b/docker-compose.yml @@ -0,0 +1,19 @@ +version: '3' + +services: + db: + image: postgres + env_file: .env + volumes: + - pgdata:/var/lib/posgresql/data + web: + build: . + command: python manage.py runserver 0.0.0.0:8000 + volumes: + - .:/code + ports: + - "8000:8000" + depends_on: + - db +volumes: + pgdata: diff --git a/fedireads/settings.py b/fedireads/settings.py index c5cdfd9b..65d86d50 100644 --- a/fedireads/settings.py +++ b/fedireads/settings.py @@ -70,25 +70,15 @@ WSGI_APPLICATION = 'fedireads.wsgi.application' # Database # https://docs.djangoproject.com/en/2.0/ref/settings/#databases -FEDIREADS_DATABASE_BACKEND = env('FEDIREADS_DATABASE_BACKEND', 'postgres') - -FEDIREADS_DBS = { - 'postgres': { - 'ENGINE': 'django.db.backends.postgresql_psycopg2', - 'NAME': 'fedireads', - 'USER': 'fedireads', - 'PASSWORD': 'fedireads', - 'HOST': '', - 'PORT': 5432 - }, - 'sqlite': { - 'ENGINE': 'django.db.backends.sqlite3', - 'NAME': os.path.join(BASE_DIR, 'fedireads.db') - } -} - DATABASES = { - 'default': FEDIREADS_DBS[FEDIREADS_DATABASE_BACKEND] + 'default': { + 'ENGINE': 'django.db.backends.postgresql_psycopg2', + 'NAME': 'postgres', + 'USER': 'postgres', + 'PASSWORD': '"%s"' % env('POSTGRES_PASSWORD', 'fedireads'), + 'HOST': 'db', + 'PORT': 5432 + } } LOGIN_URL = '/login/'