Switch to UWSGI and improve Docker definitions
This commit is contained in:
parent
23b35da282
commit
fd4cecee05
|
@ -0,0 +1,28 @@
|
||||||
|
# syntax=docker/dockerfile:1
|
||||||
|
FROM python:3
|
||||||
|
ARG OPERATION
|
||||||
|
|
||||||
|
RUN useradd -d /code pathogen
|
||||||
|
RUN mkdir -p /code
|
||||||
|
RUN chown -R pathogen:pathogen /code
|
||||||
|
|
||||||
|
RUN mkdir -p /conf/static
|
||||||
|
RUN chown -R pathogen:pathogen /conf
|
||||||
|
|
||||||
|
RUN mkdir /venv
|
||||||
|
RUN chown pathogen:pathogen /venv
|
||||||
|
|
||||||
|
USER pathogen
|
||||||
|
ENV PYTHONDONTWRITEBYTECODE=1
|
||||||
|
ENV PYTHONUNBUFFERED=1
|
||||||
|
WORKDIR /code
|
||||||
|
COPY requirements.txt /code/
|
||||||
|
RUN python -m venv /venv
|
||||||
|
RUN . /venv/bin/activate && pip install -r requirements.txt
|
||||||
|
|
||||||
|
# CMD . /venv/bin/activate && uwsgi --ini /conf/uwsgi.ini
|
||||||
|
|
||||||
|
CMD if [ "$OPERATION" = "uwsgi" ] ; then . /venv/bin/activate && uwsgi --ini /conf/uwsgi.ini ; else . /venv/bin/activate && exec python manage.py runserver 0.0.0.0:8000; fi
|
||||||
|
|
||||||
|
# CMD . /venv/bin/activate && uvicorn --reload --reload-include *.html --workers 2 --uds /var/run/socks/app.sock app.asgi:application
|
||||||
|
# CMD . /venv/bin/activate && gunicorn -b 0.0.0.0:8000 --reload app.asgi:application -k uvicorn.workers.UvicornWorker
|
|
@ -0,0 +1,20 @@
|
||||||
|
run:
|
||||||
|
docker-compose --env-file=stack.env up -d
|
||||||
|
|
||||||
|
build:
|
||||||
|
docker-compose --env-file=stack.env build
|
||||||
|
|
||||||
|
stop:
|
||||||
|
docker-compose --env-file=stack.env down
|
||||||
|
|
||||||
|
log:
|
||||||
|
docker-compose --env-file=stack.env logs -f
|
||||||
|
|
||||||
|
migrate:
|
||||||
|
docker-compose --env-file=stack.env run --rm app sh -c ". /venv/bin/activate && python manage.py migrate"
|
||||||
|
|
||||||
|
makemigrations:
|
||||||
|
docker-compose --env-file=stack.env run --rm app sh -c ". /venv/bin/activate && python manage.py makemigrations"
|
||||||
|
|
||||||
|
auth:
|
||||||
|
docker-compose --env-file=stack.env run --rm app sh -c ". /venv/bin/activate && python manage.py createsuperuser"
|
|
@ -1,18 +1,21 @@
|
||||||
version: "2"
|
version: "2.2"
|
||||||
|
|
||||||
services:
|
services:
|
||||||
app:
|
app:
|
||||||
image: pathogen/neptune:latest
|
image: pathogen/neptune:latest
|
||||||
container_name: neptune
|
container_name: neptune
|
||||||
build: ./docker
|
build:
|
||||||
|
context: .
|
||||||
|
args:
|
||||||
|
OPERATION: ${OPERATION}
|
||||||
volumes:
|
volumes:
|
||||||
- ${PORTAINER_GIT_DIR}:/code
|
- ${PORTAINER_GIT_DIR}:/code
|
||||||
- ${NEPTUNE_LOCAL_SETTINGS}:/code/app/local_settings.py
|
- ${PORTAINER_GIT_DIR}/docker/uwsgi.ini:/conf/uwsgi.ini
|
||||||
- ${NEPTUNE_DATABASE_FILE}:/code/db.sqlite3
|
- ${APP_LOCAL_SETTINGS}:/code/app/local_settings.py
|
||||||
ports:
|
- ${APP_DATABASE_FILE}:/code/db.sqlite3
|
||||||
- "${NEPTUNE_PORT}:8000"
|
- neptune_static:${STATIC_ROOT}
|
||||||
env_file:
|
env_file:
|
||||||
- .env
|
- stack.env
|
||||||
volumes_from:
|
volumes_from:
|
||||||
- tmp
|
- tmp
|
||||||
depends_on:
|
depends_on:
|
||||||
|
@ -20,6 +23,8 @@ services:
|
||||||
condition: service_healthy
|
condition: service_healthy
|
||||||
migration:
|
migration:
|
||||||
condition: service_started
|
condition: service_started
|
||||||
|
collectstatic:
|
||||||
|
condition: service_started
|
||||||
networks:
|
networks:
|
||||||
- default
|
- default
|
||||||
- pathogen
|
- pathogen
|
||||||
|
@ -28,25 +33,63 @@ services:
|
||||||
migration:
|
migration:
|
||||||
image: pathogen/neptune:latest
|
image: pathogen/neptune:latest
|
||||||
container_name: migration_neptune
|
container_name: migration_neptune
|
||||||
|
build:
|
||||||
|
context: .
|
||||||
|
args:
|
||||||
|
OPERATION: ${OPERATION}
|
||||||
command: sh -c '. /venv/bin/activate && python manage.py migrate --noinput'
|
command: sh -c '. /venv/bin/activate && python manage.py migrate --noinput'
|
||||||
volumes:
|
volumes:
|
||||||
- ${PORTAINER_GIT_DIR}:/code
|
- ${PORTAINER_GIT_DIR}:/code
|
||||||
- ${NEPTUNE_LOCAL_SETTINGS}:/code/app/local_settings.py
|
- ${APP_LOCAL_SETTINGS}:/code/app/local_settings.py
|
||||||
- ${NEPTUNE_DATABASE_FILE}:/code/db.sqlite3
|
- ${APP_DATABASE_FILE}:/code/db.sqlite3
|
||||||
|
- neptune_static:${STATIC_ROOT}
|
||||||
volumes_from:
|
volumes_from:
|
||||||
- tmp
|
- tmp
|
||||||
depends_on:
|
depends_on:
|
||||||
redis:
|
redis:
|
||||||
condition: service_healthy
|
condition: service_healthy
|
||||||
|
|
||||||
# pyroscope:
|
collectstatic:
|
||||||
# image: pyroscope/pyroscope
|
image: pathogen/neptune:latest
|
||||||
# environment:
|
container_name: collectstatic_neptune
|
||||||
# - PYROSCOPE_LOG_LEVEL=debug
|
build:
|
||||||
# ports:
|
context: .
|
||||||
# - '4040:4040'
|
args:
|
||||||
# command:
|
OPERATION: ${OPERATION}
|
||||||
# - 'server'
|
command: sh -c '. /venv/bin/activate && python manage.py collectstatic --noinput'
|
||||||
|
volumes:
|
||||||
|
- ${PORTAINER_GIT_DIR}:/code
|
||||||
|
- ${APP_LOCAL_SETTINGS}:/code/app/local_settings.py
|
||||||
|
- ${APP_DATABASE_FILE}:/code/db.sqlite3
|
||||||
|
- neptune_static:${STATIC_ROOT}
|
||||||
|
env_file:
|
||||||
|
- stack.env
|
||||||
|
depends_on:
|
||||||
|
redis:
|
||||||
|
condition: service_healthy
|
||||||
|
|
||||||
|
nginx:
|
||||||
|
image: nginx:latest
|
||||||
|
container_name: nginx_neptune
|
||||||
|
ports:
|
||||||
|
- ${APP_PORT}:9999
|
||||||
|
ulimits:
|
||||||
|
nproc: 65535
|
||||||
|
nofile:
|
||||||
|
soft: 65535
|
||||||
|
hard: 65535
|
||||||
|
volumes:
|
||||||
|
- ${PORTAINER_GIT_DIR}:/code
|
||||||
|
- ${PORTAINER_GIT_DIR}/docker/nginx/conf.d/${OPERATION}.conf:/etc/nginx/conf.d/default.conf
|
||||||
|
- neptune_static:${STATIC_ROOT}
|
||||||
|
volumes_from:
|
||||||
|
- tmp
|
||||||
|
networks:
|
||||||
|
- default
|
||||||
|
- pathogen
|
||||||
|
depends_on:
|
||||||
|
app:
|
||||||
|
condition: service_started
|
||||||
|
|
||||||
tmp:
|
tmp:
|
||||||
image: busybox
|
image: busybox
|
||||||
|
@ -81,3 +124,6 @@ networks:
|
||||||
external: true
|
external: true
|
||||||
elastic:
|
elastic:
|
||||||
external: true
|
external: true
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
neptune_static: {}
|
|
@ -1,18 +0,0 @@
|
||||||
# syntax=docker/dockerfile:1
|
|
||||||
FROM python:3
|
|
||||||
|
|
||||||
RUN useradd -d /code pathogen
|
|
||||||
RUN mkdir /code
|
|
||||||
RUN chown pathogen:pathogen /code
|
|
||||||
|
|
||||||
RUN mkdir /venv
|
|
||||||
RUN chown pathogen:pathogen /venv
|
|
||||||
|
|
||||||
USER pathogen
|
|
||||||
ENV PYTHONDONTWRITEBYTECODE=1
|
|
||||||
ENV PYTHONUNBUFFERED=1
|
|
||||||
WORKDIR /code
|
|
||||||
COPY requirements.dev.txt /code/
|
|
||||||
RUN python -m venv /venv
|
|
||||||
RUN . /venv/bin/activate && pip install -r requirements.dev.txt
|
|
||||||
CMD . /venv/bin/activate && exec python manage.py runserver 0.0.0.0:8000
|
|
|
@ -1,76 +0,0 @@
|
||||||
version: "2.2"
|
|
||||||
|
|
||||||
services:
|
|
||||||
app:
|
|
||||||
image: pathogen/neptune:latest
|
|
||||||
container_name: neptune
|
|
||||||
build: ./docker/prod
|
|
||||||
volumes:
|
|
||||||
- ${PORTAINER_GIT_DIR}:/code
|
|
||||||
- ${PORTAINER_GIT_DIR}/docker/prod/uwsgi.ini:/conf/uwsgi.ini
|
|
||||||
- ${NEPTUNE_LOCAL_SETTINGS}:/code/app/local_settings.py
|
|
||||||
- ${NEPTUNE_DATABASE_FILE}:/code/db.sqlite3
|
|
||||||
ports:
|
|
||||||
- "${NEPTUNE_PORT}:8000" # uwsgi socket
|
|
||||||
env_file:
|
|
||||||
- ../stack.env
|
|
||||||
volumes_from:
|
|
||||||
- tmp
|
|
||||||
depends_on:
|
|
||||||
redis:
|
|
||||||
condition: service_healthy
|
|
||||||
migration:
|
|
||||||
condition: service_started
|
|
||||||
networks:
|
|
||||||
- default
|
|
||||||
- pathogen
|
|
||||||
- elastic
|
|
||||||
|
|
||||||
migration:
|
|
||||||
image: pathogen/neptune:latest
|
|
||||||
container_name: migration_neptune
|
|
||||||
build: ./docker/prod
|
|
||||||
command: sh -c '. /venv/bin/activate && python manage.py migrate --noinput'
|
|
||||||
volumes:
|
|
||||||
- ${PORTAINER_GIT_DIR}:/code
|
|
||||||
- ${NEPTUNE_LOCAL_SETTINGS}:/code/app/local_settings.py
|
|
||||||
- ${NEPTUNE_DATABASE_FILE}:/code/db.sqlite3
|
|
||||||
volumes_from:
|
|
||||||
- tmp
|
|
||||||
depends_on:
|
|
||||||
redis:
|
|
||||||
condition: service_healthy
|
|
||||||
|
|
||||||
tmp:
|
|
||||||
image: busybox
|
|
||||||
container_name: tmp_neptune
|
|
||||||
command: chmod -R 777 /var/run/socks
|
|
||||||
volumes:
|
|
||||||
- /var/run/socks
|
|
||||||
|
|
||||||
redis:
|
|
||||||
image: redis
|
|
||||||
container_name: redis_neptune
|
|
||||||
command: redis-server /etc/redis.conf
|
|
||||||
ulimits:
|
|
||||||
nproc: 65535
|
|
||||||
nofile:
|
|
||||||
soft: 65535
|
|
||||||
hard: 65535
|
|
||||||
volumes:
|
|
||||||
- ${PORTAINER_GIT_DIR}/docker/redis.conf:/etc/redis.conf
|
|
||||||
volumes_from:
|
|
||||||
- tmp
|
|
||||||
healthcheck:
|
|
||||||
test: "redis-cli -s /var/run/socks/redis.sock ping"
|
|
||||||
interval: 2s
|
|
||||||
timeout: 2s
|
|
||||||
retries: 15
|
|
||||||
|
|
||||||
networks:
|
|
||||||
default:
|
|
||||||
driver: bridge
|
|
||||||
pathogen:
|
|
||||||
external: true
|
|
||||||
elastic:
|
|
||||||
external: true
|
|
|
@ -0,0 +1,23 @@
|
||||||
|
upstream django {
|
||||||
|
#server app:8000;
|
||||||
|
#server unix:///var/run/socks/app.sock;
|
||||||
|
server app:8000;
|
||||||
|
}
|
||||||
|
|
||||||
|
server {
|
||||||
|
listen 9999;
|
||||||
|
|
||||||
|
location = /favicon.ico { access_log off; log_not_found off; }
|
||||||
|
|
||||||
|
location /static/ {
|
||||||
|
root /conf;
|
||||||
|
}
|
||||||
|
|
||||||
|
location / {
|
||||||
|
proxy_pass http://django;
|
||||||
|
proxy_set_header X-Real-IP $remote_addr;
|
||||||
|
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
||||||
|
proxy_set_header Host $host;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,24 @@
|
||||||
|
upstream django {
|
||||||
|
server app:8000;
|
||||||
|
#server unix:///var/run/socks/app.sock;
|
||||||
|
}
|
||||||
|
|
||||||
|
server {
|
||||||
|
listen 9999;
|
||||||
|
|
||||||
|
location = /favicon.ico { access_log off; log_not_found off; }
|
||||||
|
|
||||||
|
location /static/ {
|
||||||
|
root /conf;
|
||||||
|
}
|
||||||
|
|
||||||
|
location / {
|
||||||
|
include /etc/nginx/uwsgi_params; # the uwsgi_params file you installed
|
||||||
|
uwsgi_pass django;
|
||||||
|
uwsgi_param Host $host;
|
||||||
|
uwsgi_param X-Real-IP $remote_addr;
|
||||||
|
uwsgi_param X-Forwarded-For $proxy_add_x_forwarded_for;
|
||||||
|
uwsgi_param X-Forwarded-Proto $http_x_forwarded_proto;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -1,21 +0,0 @@
|
||||||
# syntax=docker/dockerfile:1
|
|
||||||
FROM python:3
|
|
||||||
|
|
||||||
RUN useradd -d /code pathogen
|
|
||||||
RUN mkdir /code
|
|
||||||
RUN chown pathogen:pathogen /code
|
|
||||||
|
|
||||||
RUN mkdir /conf
|
|
||||||
RUN chown pathogen:pathogen /conf
|
|
||||||
|
|
||||||
RUN mkdir /venv
|
|
||||||
RUN chown pathogen:pathogen /venv
|
|
||||||
|
|
||||||
USER pathogen
|
|
||||||
ENV PYTHONDONTWRITEBYTECODE=1
|
|
||||||
ENV PYTHONUNBUFFERED=1
|
|
||||||
WORKDIR /code
|
|
||||||
COPY requirements.prod.txt /code/
|
|
||||||
RUN python -m venv /venv
|
|
||||||
RUN . /venv/bin/activate && pip install -r requirements.prod.txt
|
|
||||||
CMD . /venv/bin/activate && uwsgi --ini /conf/uwsgi.ini
|
|
|
@ -1,19 +0,0 @@
|
||||||
wheel
|
|
||||||
django
|
|
||||||
django-crispy-forms
|
|
||||||
crispy-bulma
|
|
||||||
elasticsearch
|
|
||||||
stripe
|
|
||||||
django-rest-framework
|
|
||||||
numpy
|
|
||||||
uwsgi
|
|
||||||
django-tables2
|
|
||||||
django-tables2-bulma-template
|
|
||||||
django-htmx
|
|
||||||
cryptography
|
|
||||||
siphashc
|
|
||||||
redis
|
|
||||||
sortedcontainers
|
|
||||||
django-debug-toolbar
|
|
||||||
django-debug-toolbar-template-profiler
|
|
||||||
orjson
|
|
|
@ -1,18 +0,0 @@
|
||||||
wheel
|
|
||||||
django
|
|
||||||
django-crispy-forms
|
|
||||||
crispy-bulma
|
|
||||||
elasticsearch
|
|
||||||
stripe
|
|
||||||
django-rest-framework
|
|
||||||
numpy
|
|
||||||
django-tables2
|
|
||||||
django-tables2-bulma-template
|
|
||||||
django-htmx
|
|
||||||
cryptography
|
|
||||||
siphashc
|
|
||||||
redis
|
|
||||||
sortedcontainers
|
|
||||||
django-debug-toolbar
|
|
||||||
django-debug-toolbar-template-profiler
|
|
||||||
orjson
|
|
|
@ -5,9 +5,8 @@ env=DJANGO_SETTINGS_MODULE=app.settings
|
||||||
master=1
|
master=1
|
||||||
pidfile=/tmp/project-master.pid
|
pidfile=/tmp/project-master.pid
|
||||||
socket=0.0.0.0:8000
|
socket=0.0.0.0:8000
|
||||||
processes=5
|
|
||||||
harakiri=20
|
harakiri=20
|
||||||
max-requests=5000
|
max-requests=100000
|
||||||
vacuum=1
|
vacuum=1
|
||||||
home=/venv
|
home=/venv
|
||||||
|
processes=12
|
|
@ -1,4 +1,5 @@
|
||||||
wheel
|
wheel
|
||||||
|
uwsgi
|
||||||
django
|
django
|
||||||
pre-commit
|
pre-commit
|
||||||
django-crispy-forms
|
django-crispy-forms
|
||||||
|
|
10
stack.env
10
stack.env
|
@ -1,4 +1,6 @@
|
||||||
NEPTUNE_PORT=5000
|
APP_PORT=5000
|
||||||
PORTAINER_GIT_DIR=..
|
PORTAINER_GIT_DIR=.
|
||||||
NEPTUNE_LOCAL_SETTINGS=../app/local_settings.py
|
APP_LOCAL_SETTINGS=./app/local_settings.py
|
||||||
NEPTUNE_DATABASE_FILE=../db.sqlite3
|
APP_DATABASE_FILE=./db.sqlite3
|
||||||
|
STATIC_ROOT=/conf/static
|
||||||
|
OPERATION=uwsgi
|
Loading…
Reference in New Issue