2020-09-02 22:04:12 +00:00
|
|
|
"""Gunicorn config"""
|
2020-11-11 13:48:19 +00:00
|
|
|
import os
|
2020-11-02 09:26:26 +00:00
|
|
|
import warnings
|
2020-09-11 21:21:11 +00:00
|
|
|
from multiprocessing import cpu_count
|
|
|
|
|
2020-09-02 22:04:12 +00:00
|
|
|
import structlog
|
2021-04-07 14:16:17 +00:00
|
|
|
from kubernetes.config.incluster_config import SERVICE_HOST_ENV_NAME
|
2020-09-02 22:04:12 +00:00
|
|
|
|
2021-05-04 15:49:21 +00:00
|
|
|
bind = "127.0.0.1:8000"
|
2020-09-02 22:04:12 +00:00
|
|
|
|
2020-12-05 21:08:42 +00:00
|
|
|
user = "authentik"
|
|
|
|
group = "authentik"
|
2020-09-02 22:04:12 +00:00
|
|
|
|
|
|
|
worker_class = "uvicorn.workers.UvicornWorker"
|
2020-09-06 20:16:12 +00:00
|
|
|
# Docker containers don't have /tmp as tmpfs
|
2020-12-07 10:21:07 +00:00
|
|
|
worker_tmp_dir = "/dev/shm" # nosec
|
2020-09-02 22:04:12 +00:00
|
|
|
|
2020-12-05 21:08:42 +00:00
|
|
|
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "authentik.root.settings")
|
2020-11-11 13:48:19 +00:00
|
|
|
|
2020-09-02 22:04:12 +00: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 13:52:48 +00:00
|
|
|
"loggers": {
|
2020-09-06 14:12:17 +00:00
|
|
|
"uvicorn": {"handlers": ["console"], "level": "WARNING", "propagate": False},
|
|
|
|
"gunicorn": {"handlers": ["console"], "level": "INFO", "propagate": False},
|
2020-09-06 13:52:48 +00:00
|
|
|
},
|
2020-09-02 22:04:12 +00:00
|
|
|
}
|
2020-09-11 21:21:11 +00: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
|
2021-04-07 14:16:17 +00:00
|
|
|
if SERVICE_HOST_ENV_NAME in os.environ:
|
2020-09-11 21:21:11 +00:00
|
|
|
workers = 2
|
|
|
|
else:
|
2021-08-05 08:15:31 +00:00
|
|
|
default_workers = max(cpu_count() * 0.25, 1) + 1 # Minimum of 2 workers
|
2021-08-04 19:37:13 +00:00
|
|
|
workers = int(os.environ.get("WORKERS", default_workers))
|
2020-09-11 21:21:11 +00:00
|
|
|
threads = 4
|
2020-11-02 09:26:26 +00:00
|
|
|
|
2021-08-08 22:27:29 +00:00
|
|
|
warnings.filterwarnings(
|
|
|
|
"ignore",
|
|
|
|
message="defusedxml.lxml is no longer supported and will be removed in a future release.",
|
|
|
|
)
|
|
|
|
warnings.filterwarnings(
|
|
|
|
"ignore",
|
|
|
|
message="defusedxml.cElementTree is deprecated, import from defusedxml.ElementTree instead.",
|
|
|
|
)
|
|
|
|
warnings.filterwarnings(
|
|
|
|
"ignore",
|
|
|
|
message=(
|
|
|
|
"'django_prometheus' defines default_app_config = 'django_prometheus.apps.DjangoPromethe"
|
|
|
|
"usConfig'. Django now detects this configuration automatically. You can remove d"
|
|
|
|
"efault_app_config."
|
|
|
|
),
|
|
|
|
)
|
|
|
|
warnings.filterwarnings(
|
|
|
|
"ignore",
|
|
|
|
message=(
|
|
|
|
"'dbbackup' defines default_app_config = 'dbbackup.apps.DbbackupConfig'. Django now det"
|
2021-08-08 23:07:50 +00:00
|
|
|
"ects this configuration automatically. You can remove default_app_config."
|
2021-08-08 22:27:29 +00:00
|
|
|
),
|
|
|
|
)
|
2020-11-02 09:26:26 +00:00
|
|
|
warnings.simplefilter("once")
|