mirror of https://github.com/interlegis/sapl.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
74 lines
2.0 KiB
74 lines
2.0 KiB
# /var/interlegis/sapl/gunicorn.conf.py
|
|
|
|
import os
|
|
import pathlib
|
|
import multiprocessing
|
|
|
|
# ---- SAPL app configuration ----
|
|
NAME = "SAPL"
|
|
DJANGODIR = "/var/interlegis/sapl/"
|
|
SOCKFILE = "/var/interlegis/sapl/run/gunicorn.sock"
|
|
# USER = os.getenv("RUN_AS_USER", os.getenv("USER", "nginx"))
|
|
# GROUP = os.getenv("RUN_AS_GROUP", USER)
|
|
NUM_WORKERS = 11 # keep your explicit value
|
|
TIMEOUT = 300
|
|
MAX_REQUESTS = 100
|
|
DJANGO_SETTINGS = "sapl.settings"
|
|
WSGI_APP = "sapl.wsgi:application"
|
|
|
|
# ---- gunicorn settings ----
|
|
# Equivalent of: --name
|
|
proc_name = NAME
|
|
|
|
# Equivalent of: --bind=unix:...
|
|
# For quick testing via browser, you can switch to: bind = "0.0.0.0:8000"
|
|
bind = f"unix:{SOCKFILE}"
|
|
|
|
# Ensure imports work like in your script’s working dir
|
|
chdir = DJANGODIR
|
|
|
|
# Allow starting with just: gunicorn -c gunicorn.conf.py
|
|
wsgi_app = WSGI_APP
|
|
|
|
# Logs
|
|
loglevel = "debug"
|
|
errorlog = "-" # send to stderr (so you see it in docker logs or terminal)
|
|
accesslog = "-" # send to stdout
|
|
# accesslog = "/var/log/sapl/access.log"
|
|
# errorlog = "/var/log/sapl/error.log"
|
|
|
|
# Worker/process lifecycle
|
|
workers = NUM_WORKERS
|
|
timeout = TIMEOUT
|
|
graceful_timeout = 30
|
|
max_requests = MAX_REQUESTS
|
|
max_requests_jitter = 0
|
|
|
|
# Drop privileges (only applies if started as root)
|
|
# user = USER
|
|
# group = GROUP
|
|
|
|
# Environment (same as exporting before running)
|
|
raw_env = [
|
|
f"DJANGO_SETTINGS_MODULE={DJANGO_SETTINGS}",
|
|
# If you’re using ReportLab and seeing segfaults with PDFs, keep this:
|
|
# "RL_NOACCEL=1",
|
|
]
|
|
|
|
# If you previously enabled preload and saw segfaults with native libs, keep it off:
|
|
preload_app = False
|
|
|
|
|
|
# Create the run/ directory for the UNIX socket (your script did this)
|
|
def on_starting(server):
|
|
pathlib.Path(SOCKFILE).parent.mkdir(parents=True, exist_ok=True)
|
|
|
|
|
|
# Close DB connections after fork (safer when using preload or certain DB drivers)
|
|
def post_fork(server, worker):
|
|
try:
|
|
from django import db
|
|
db.connections.close_all()
|
|
except Exception:
|
|
# Django not initialized yet or not available
|
|
pass
|
|
|