 1cfe1aff13
			
		
	
	1cfe1aff13
	
	
	
		
			
			* root: initial rename * web: rename custom element prefix * root: rename external functions with pb_ prefix * root: fix formatting * root: replace domain with goauthentik.io * proxy: update path * root: rename remaining prefixes * flows: rename file extension * root: pbadmin -> akadmin * docs: fix image filenames * lifecycle: ignore migration files * ci: copy default config from current source before loading last tagged * *: new sentry dsn * tests: fix missing python3.9-dev package * root: add additional migrations for service accounts created by outposts * core: mark system-created service accounts with attribute * policies/expression: fix pb_ replacement not working * web: fix last linting errors, add lit-analyse * policies/expressions: fix lint errors * web: fix sidebar display on screens where not all items fit * proxy: attempt to fix proxy pipeline * proxy: use go env GOPATH to get gopath * lib: fix user_default naming inconsistency * docs: add upgrade docs * docs: update screenshots to use authentik * admin: fix create button on empty-state of outpost * web: fix modal submit not refreshing SiteShell and Table * web: fix height of app-card and height of generic icon * web: fix rendering of subtext * admin: fix version check error not being caught * web: fix worker count not being shown * docs: update screenshots * root: new icon * web: fix lint error * admin: fix linting error * root: migrate coverage config to pyproject
		
			
				
	
	
		
			58 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			58 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| """Gunicorn config"""
 | |
| import os
 | |
| import warnings
 | |
| from multiprocessing import cpu_count
 | |
| from pathlib import Path
 | |
| 
 | |
| import structlog
 | |
| 
 | |
| bind = "0.0.0.0:8000"
 | |
| 
 | |
| user = "authentik"
 | |
| group = "authentik"
 | |
| 
 | |
| worker_class = "uvicorn.workers.UvicornWorker"
 | |
| # Docker containers don't have /tmp as tmpfs
 | |
| worker_tmp_dir = "/dev/shm"
 | |
| 
 | |
| 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 Path("/var/run/secrets/kubernetes.io").exists():
 | |
|     workers = 2
 | |
| else:
 | |
|     worker = cpu_count() * 2 + 1
 | |
| threads = 4
 | |
| 
 | |
| warnings.simplefilter("once")
 |