Май 23, 2026Кіраўніцтва
Як наладзіць зваротны проксі Nginx
Proxy Node.js, Docker або іншыя праграмы праз Nginx з падтрымкай WebSocket і SSL на вашым VPS.

Зваротны проксі дазваляе Nginx прымаць агульнадаступны трафік HTTP/HTTPS і перанакіроўваць яго ў серверныя прыкладанні (Node.js на порце 3000, кантэйнеры Docker, API Python). Істотны для вытворчага разгортвання на Hiddence VPS.
Перадумовы
- Nginx усталяваны і працуе
- Бэкэнд-праграма праслухоўвае лакальны хост (напрыклад, 127.0.0.1:3000)
- Дамен паказвае на ваш VPS (для SSL)
- Парты 80 і 443 адкрыты ў брандмаўэры
Базавая канфігурацыя зваротнага проксі
Стварыце канфігурацыю сайта для вашага дамена:
bash
server {
listen 80;
server_name app.yourdomain.com;
location / {
proxy_pass http://127.0.0.1:3000;
proxy_http_version 1.1;
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;
}
}
sudo nginx -t && sudo systemctl reload nginxПадтрымка WebSocket
Патрабуецца для Socket.io, многіх панэляў кіравання і праграм у рэжыме рэальнага часу:
bash
location / {
proxy_pass http://127.0.0.1:3000;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_set_header Host $host;
}Дадайце HTTPS з Certbot
Пасля працы HTTP выдайце бясплатны сертыфікат:
bash
sudo apt install certbot python3-certbot-nginx -y
sudo certbot --nginx -d app.yourdomain.com
# Certbot will update your server block for SSL automaticallyПарады
- Пры неабходнасці выкарыстоўвайце proxy_buffering для струменевай перадачы/SSE
- Усталюйце client_max_body_size для загрузкі файлаў
- Запусціце некалькі бэкэндаў на розных субдаменах
- Выкарыстоўвайце блокі ўверх па плыні для балансіроўкі нагрузкі некалькіх бэкэндаў
- Праверце error.log, калі вы атрымаеце 502 Bad Gateway