gunicorn/examples/dirty_example/gunicorn_conf.py
Benoit Chesneau c0cc8c0de0 test(dirty): add Docker setup for dirty example integration tests
- Add Dockerfile and docker-compose.yml for running examples in containers
- Add test_integration.py for HTTP-level integration testing
- Update test_worker_integration.py to use MockWriter for handle_request
- Use integer request IDs for binary protocol compatibility
- Add GUNICORN_BIND env var support in gunicorn_conf.py for Docker
2026-02-11 23:30:48 +01:00

62 lines
1.4 KiB
Python

#
# This file is part of gunicorn released under the MIT license.
# See the NOTICE for more information.
"""
Gunicorn configuration for Dirty Workers Example
Run with:
cd examples/dirty_example
gunicorn wsgi_app:app -c gunicorn_conf.py
"""
# Basic settings
# Use 0.0.0.0 for Docker, override with GUNICORN_BIND env var if needed
import os
bind = os.environ.get("GUNICORN_BIND", "127.0.0.1:8000")
workers = 2
worker_class = "sync"
timeout = 30
# Dirty arbiter settings
dirty_apps = [
"examples.dirty_example.dirty_app:MLApp",
"examples.dirty_example.dirty_app:ComputeApp",
]
dirty_workers = 2
dirty_timeout = 300
dirty_graceful_timeout = 30
# Logging
loglevel = "info"
accesslog = "-"
errorlog = "-"
# Hooks for demonstration
def on_starting(server):
print("=== Gunicorn starting ===")
def when_ready(server):
print("=== Gunicorn ready ===")
print(f"HTTP workers: {server.num_workers}")
print(f"Dirty workers: {server.cfg.dirty_workers}")
print(f"Dirty apps: {server.cfg.dirty_apps}")
def on_dirty_starting(arbiter):
print("=== Dirty arbiter starting ===")
def dirty_post_fork(arbiter, worker):
print(f"=== Dirty worker {worker.pid} forked ===")
def dirty_worker_init(worker):
print(f"=== Dirty worker {worker.pid} initialized apps ===")
def dirty_worker_exit(arbiter, worker):
print(f"=== Dirty worker {worker.pid} exiting ===")