authentik/lifecycle/gunicorn.conf.py

58 lines
1.7 KiB
Python
Raw Normal View History

2020-09-02 15:04:12 -07:00
"""Gunicorn config"""
import os
import warnings
2020-09-11 14:21:11 -07:00
from multiprocessing import cpu_count
2020-09-02 15:04:12 -07:00
import structlog
from kubernetes.config.incluster_config import SERVICE_HOST_ENV_NAME
2020-09-02 15:04:12 -07:00
bind = "127.0.0.1:8000"
2020-09-02 15:04:12 -07:00
2020-12-05 13:08:42 -08:00
user = "authentik"
group = "authentik"
2020-09-02 15:04:12 -07:00
worker_class = "uvicorn.workers.UvicornWorker"
# Docker containers don't have /tmp as tmpfs
worker_tmp_dir = "/dev/shm" # nosec
2020-09-02 15:04:12 -07:00
2020-12-05 13:08:42 -08:00
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "authentik.root.settings")
2020-09-02 15:04:12 -07:00
logconfig_dict = {
"version": 1,
"disable_existing_loggers": False,
"formatters": {
"json_formatter": {
"()": structlog.stdlib.ProcessorFormatter,
"processor": structlog.processors.JSONRenderer(),
"foreign_pre_chain": [
structlog.stdlib.add_log_level,
structlog.stdlib.add_logger_name,
structlog.processors.TimeStamper(),
structlog.processors.StackInfoRenderer(),
structlog.processors.format_exc_info,
],
}
},
"handlers": {
"error_console": {
"class": "logging.StreamHandler",
"formatter": "json_formatter",
},
"console": {"class": "logging.StreamHandler", "formatter": "json_formatter"},
},
2020-09-06 06:52:48 -07:00
"loggers": {
"uvicorn": {"handlers": ["console"], "level": "WARNING", "propagate": False},
"gunicorn": {"handlers": ["console"], "level": "INFO", "propagate": False},
2020-09-06 06:52:48 -07:00
},
2020-09-02 15:04:12 -07:00
}
2020-09-11 14:21:11 -07:00
# if we're running in kubernetes, use fixed workers because we can scale with more pods
# otherwise (assume docker-compose), use as much as we can
if SERVICE_HOST_ENV_NAME in os.environ:
2020-09-11 14:21:11 -07:00
workers = 2
else:
workers = int(os.environ.get("WORKERS", cpu_count() * 2 + 1))
2020-09-11 14:21:11 -07:00
threads = 4
warnings.simplefilter("once")