82 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			82 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
"""Gunicorn config"""
 | 
						|
import os
 | 
						|
import warnings
 | 
						|
from multiprocessing import cpu_count
 | 
						|
 | 
						|
import structlog
 | 
						|
from kubernetes.config.incluster_config import SERVICE_HOST_ENV_NAME
 | 
						|
 | 
						|
bind = "127.0.0.1:8000"
 | 
						|
 | 
						|
user = "authentik"
 | 
						|
group = "authentik"
 | 
						|
 | 
						|
worker_class = "uvicorn.workers.UvicornWorker"
 | 
						|
# Docker containers don't have /tmp as tmpfs
 | 
						|
worker_tmp_dir = "/dev/shm"  # nosec
 | 
						|
 | 
						|
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "authentik.root.settings")
 | 
						|
 | 
						|
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"},
 | 
						|
    },
 | 
						|
    "loggers": {
 | 
						|
        "uvicorn": {"handlers": ["console"], "level": "WARNING", "propagate": False},
 | 
						|
        "gunicorn": {"handlers": ["console"], "level": "INFO", "propagate": False},
 | 
						|
    },
 | 
						|
}
 | 
						|
 | 
						|
# 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:
 | 
						|
    workers = 2
 | 
						|
else:
 | 
						|
    default_workers = max(cpu_count() * 0.25, 1) + 1  # Minimum of 2 workers
 | 
						|
    workers = int(os.environ.get("WORKERS", default_workers))
 | 
						|
threads = 4
 | 
						|
 | 
						|
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"
 | 
						|
        "ects this configuration automatically. You can remove default_app_config."
 | 
						|
    ),
 | 
						|
)
 | 
						|
warnings.simplefilter("once")
 |