~/notes / nginx-django-reverse-proxy

2026-02-24🐧 Linux1 мин0 просм.

nginx как reverse proxy для Django: полная настройка

Схема работы

nginx принимает запросы снаружи и проксирует их на uvicorn/gunicorn, который слушает на localhost. Статику и медиафайлы nginx отдаёт сам — это быстрее.

Базовый конфиг

upstream django {
    server 127.0.0.1:8000;
}

server {
    listen 80;
    server_name example.com;

    location /static/ {
        alias /srv/myapp/staticfiles/;
        expires 30d;
    }

    location /media/ {
        alias /srv/myapp/media/;
    }

    location / {
        proxy_pass http://django;
        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;
    }
}

SSL через certbot

sudo apt install certbot python3-certbot-nginx
sudo certbot --nginx -d example.com

certbot сам добавит нужные директивы в конфиг и настроит автообновление сертификата.

Rate limiting

limit_req_zone $binary_remote_addr zone=api:10m rate=10r/s;

location /api/ {
    limit_req zone=api burst=20 nodelay;
    proxy_pass http://django;
}

Буферизация и таймауты

proxy_connect_timeout 60s;
proxy_send_timeout 60s;
proxy_read_timeout 60s;
proxy_buffering on;
proxy_buffer_size 4k;
proxy_buffers 8 4k;

Для WebSocket отключай буферизацию: proxy_buffering off.

Проверка конфига

sudo nginx -t && sudo systemctl reload nginx

Всегда проверяй конфиг перед reload — синтаксическая ошибка положит весь nginx.