Docker setup

This commit is contained in:
Jannis Portmann 2023-04-07 10:58:28 +02:00
parent 2a2545a348
commit fa96ad7ea3
7 changed files with 97 additions and 3 deletions

5
.dockerignore Normal file
View file

@ -0,0 +1,5 @@
venv
target
__pycache__
pflaenzli/media
*.sqlite3

19
Dockerfile Normal file
View file

@ -0,0 +1,19 @@
FROM python:3.11
RUN apt update && apt install -y libpq-dev nginx
ADD requirements.txt requirements.txt
RUN pip install -r requirements.txt
COPY pflaenzli /app
COPY entrypoint.sh /app
COPY default /etc/nginx/sites-enabled/default
WORKDIR /app
RUN chmod +x entrypoint.sh
RUN python3 manage.py collectstatic --no-input -c
ENTRYPOINT /app/entrypoint.sh

27
Jenkinsfile vendored Normal file
View file

@ -0,0 +1,27 @@
pipeline {
agent any
stages {
stage('Pull git') {
checkout scm
}
stage('Build Docker Image') {
steps {
script {
def dockerImage = docker.build('pflaenzli', '-f Dockerfile . --tag pflaenzli:${env.BUILD_NUMBER}')
}
}
}
stage('Push Docker Image') {
steps {
script {
docker.withRegistry('https://git.thisfro.ch', 'jenkins-ci') {
dockerImage.push()
}
}
}
}
}
}

19
default Normal file
View file

@ -0,0 +1,19 @@
server {
listen 80;
charset utf-8;
location /static {
access_log off;
alias /app/pflaenzli/static_collected;
}
location / {
proxy_pass http://127.0.0.1:8000;
proxy_set_header Host $host;
proxy_set_header X-Forwarded-Host $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
access_log off;
client_max_body_size 10M;
}
}

18
docker-compose.yml Normal file
View file

@ -0,0 +1,18 @@
version: '3'
services:
pflaenzli:
build: .
ports:
- 8080:80
environment:
DOCKER: True
db:
image: postgres:15
command: postgres -c password_encryption=md5
environment:
POSTGRES_PASSWORD: development
POSTGRES_USER: pflaenzli
POSTGRES_DB: pflaenzli
POSTGRES_INITDB_ARGS: "--auth-local=md5"

6
entrypoint.sh Normal file
View file

@ -0,0 +1,6 @@
#!/bin/bash
python manage.py migrate
nginx
gunicorn --bind :8000 --workers 4 pflaenzli_django.wsgi:application

View file

@ -32,8 +32,8 @@ SECRET_KEY = "django-insecure-q=ps#iypevr!3zfpwtfp3lw#4r3%oyj*(2=*iq^8f4_zbodi^(
# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True
ALLOWED_HOSTS = []
ALLOWED_HOSTS = ["localhost"]
CSRF_TRUSTED_ORIGINS = ["http://localhost:8080", "https://staging.pflaenz.li"]
# Application definition
@ -144,7 +144,7 @@ USE_TZ = True
STATIC_URL = "static/"
MEDIA_ROOT = os.path.join(BASE_DIR, "media")
MEDIA_URL = "media/"
STATIC_ROOT = "/app/pflaenzli/static_collected"
# Default primary key field type
# https://docs.djangoproject.com/en/4.1/ref/settings/#default-auto-field