Spaces:
Running
Running
| events { | |
| worker_connections 1024; | |
| } | |
| http { | |
| upstream api { | |
| server api:8000; | |
| } | |
| # Rate limiting | |
| limit_req_zone $binary_remote_addr zone=api:10m rate=10r/s; | |
| server { | |
| listen 80; | |
| server_name localhost; | |
| # Security headers | |
| add_header X-Frame-Options DENY; | |
| add_header X-Content-Type-Options nosniff; | |
| add_header X-XSS-Protection "1; mode=block"; | |
| # API routes | |
| location / { | |
| limit_req zone=api burst=20 nodelay; | |
| proxy_pass http://api; | |
| proxy_set_header Host $host; | |
| proxy_set_header X-Real-IP $remote_addr; | |
| proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | |
| proxy_set_header X-Forwarded-Proto $scheme; | |
| # Timeouts | |
| proxy_connect_timeout 60s; | |
| proxy_send_timeout 60s; | |
| proxy_read_timeout 90s; | |
| } | |
| # Health check endpoint (no rate limiting) | |
| location /health { | |
| proxy_pass http://api; | |
| proxy_set_header Host $host; | |
| proxy_set_header X-Real-IP $remote_addr; | |
| proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | |
| proxy_set_header X-Forwarded-Proto $scheme; | |
| } | |
| } | |
| } | |