summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorYulqen <246857+yulqen@users.noreply.github.com>2024-05-23 15:35:49 +0100
committerGitHub <noreply@github.com>2024-05-23 15:35:49 +0100
commitc89d53a2921e4e6b681c6a9dc97f7cc8eeb43956 (patch)
tree345d5259906a72a145095a6e465689d8d8a513d0
parent88dacb9f57a40c96f48c359275fe11f85aa1f051 (diff)
parent5f9ca9b3e597a9dfda9ffb3af25a60b2c7309986 (diff)
Merge pull request #50 from defencedigital/postgres-migration
Postgres migration
-rw-r--r--Dockerfile44
-rw-r--r--Dockerfile_postgresql6
-rw-r--r--Makefile22
-rw-r--r--conf/settings/base.py (renamed from ded/settings.py)0
-rw-r--r--conf/settings/local.py12
-rwxr-xr-xmanage.py1
-rw-r--r--requirements.txt1
7 files changed, 49 insertions, 37 deletions
diff --git a/Dockerfile b/Dockerfile
index 16bb14c..dca00bd 100644
--- a/Dockerfile
+++ b/Dockerfile
@@ -1,45 +1,23 @@
-# Builder stage
-FROM registry.access.redhat.com/ubi9/python-311:1-52.1712567218 AS builder
-
-# Add application sources
-USER 0
-COPY . /app
-RUN mkdir -p /app/static/css /app/static/js /app/static/img
-RUN chown -R 1001:0 /app
-USER 1001
-
-WORKDIR /app
-
-# Install dependencies
-RUN pip install -U "pip>=24.0.0" && \
- pip install -r requirements.txt && \
- python manage.py collectstatic --noinput
-
-# Final stage
FROM python:3.11-slim
# Set working directory
WORKDIR /app
-# Copy from builder
-COPY --from=builder /app /app
-
-# Install packages
-RUN pip install -r requirements.txt
+# Copy application code
+COPY . /app
-# Copy across db file and set permissions
-COPY db.sqlite3 /app/db.sqlite3
-RUN chown 1001:0 /app && \
- chmod 664 /app/db.sqlite3
+# Install system dependencies
+RUN apt-get update && apt-get install -y \
+ libpq-dev \
+ gcc \
+ && rm -rf /var/lib/apt/lists/*
-# Set user
-USER 1001
+# Install Python dependencies
+RUN pip install --no-cache-dir -r requirements.txt
-# Migrate database
-RUN python manage.py migrate
+ENV DJANGO_SETTINGS_MODULE=conf.settings.local
-# Expose port
EXPOSE 8000
-# Start app
+# Start gunicorn
CMD ["gunicorn", "ded.wsgi:application", "--bind", "0.0.0.0:8000"]
diff --git a/Dockerfile_postgresql b/Dockerfile_postgresql
new file mode 100644
index 0000000..9111660
--- /dev/null
+++ b/Dockerfile_postgresql
@@ -0,0 +1,6 @@
+FROM registry.redhat.io/rhel9/postgresql-16
+
+ENV POSTGRESQL_USER=postgres \
+ POSTGRESQL_PASSWORD=postgres
+
+CMD ["/usr/bin/run-postgresql"]
diff --git a/Makefile b/Makefile
index 556e2ba..795701d 100644
--- a/Makefile
+++ b/Makefile
@@ -1,12 +1,26 @@
+all: stop create-network build-postgres run-postgres build-django run-django
+
+CONFIG := conf.settings.local
+
runserver:
python manage.py runserver 0.0.0.0:8000
-runserver-docker:
- docker run -it --name ded -d --rm -p 8000:8000 ded:latest
+create-network:
+ -docker network create dednetwork
+stop:
+ -docker stop ded-web postgres
runserver-docker-with-vol:
docker run -it --name ded -d --rm -p 8000:8000 -v $(PWD):/app ded:latest
sync:
git pull && git checkout main && git pull && git merge pyswitch && git checkout pyswitch && git rebase main && git push
-build:
- docker build -t ded:latest .
+build-django:
+ docker build -f Dockerfile -t ded-web:latest .
+build-postgres:
+ docker build -t dso-quay-registry-quay-quay-enterprise.apps.ocp1.azure.dso.digital.mod.uk/defnucsyr-dev-team-a/postgresql:v1.0.0 . -f Dockerfile_postgresql
+run-postgres:
+ docker run -it --name postgres -d --rm -e POSTGRESQL_PASSWORD=ded -e POSTGRESQL_USER=ded -e POSTGRESQL_DATABASE=ded -p 5432:5432 --network dednetwork dso-quay-registry-quay-quay-enterprise.apps.ocp1.azure.dso.digital.mod.uk/defnucsyr-dev-team-a/postgresql:v1.0.0
+run-django:
+ docker run -d -it --name ded-web -e DJANGO_SETTINGS_MODULE=$(CONFIG) -p 8000:8000 --network dednetwork --rm ded-web:latest
test:
python manage.py test
+migrate-and-superuser:
+ docker exec -it ded-web sh -c "python manage.py migrate && python manage.py createsuperuser"
diff --git a/ded/settings.py b/conf/settings/base.py
index a16c488..a16c488 100644
--- a/ded/settings.py
+++ b/conf/settings/base.py
diff --git a/conf/settings/local.py b/conf/settings/local.py
new file mode 100644
index 0000000..0992726
--- /dev/null
+++ b/conf/settings/local.py
@@ -0,0 +1,12 @@
+from .base import *
+
+DATABASES = {
+ "default": {
+ "ENGINE": "django.db.backends.postgresql",
+ "NAME": "ded",
+ "USER": "ded",
+ "PASSWORD": "ded",
+ "HOST": "postgres",
+ "PORT": 5432,
+ }
+}
diff --git a/manage.py b/manage.py
index 47da0a5..114b143 100755
--- a/manage.py
+++ b/manage.py
@@ -1,5 +1,6 @@
#!/usr/bin/env python
"""Django's command-line utility for administrative tasks."""
+
import os
import sys
diff --git a/requirements.txt b/requirements.txt
index f3dae6d..9d62c5a 100644
--- a/requirements.txt
+++ b/requirements.txt
@@ -4,3 +4,4 @@ django-crispy-forms
#faker>=13.14.0,<14.0.0
django-htmx==1.17.3
gunicorn==22.0.0
+psycopg2==2.9.9