У меня есть API и веб-приложение, которые работают в одном кластере докеров.
1) Лучше всего иметь один контейнер nginx для балансировки нагрузки двух или два отдельных контейнера nginx для балансировки нагрузки каждый отдельно?
2) Если первое, я пробовал это:
server {
listen 80;
server_name xxy.com;
return 301 https://$host$request_uri;
}
server {
listen 443 ssl;
server_name
xxy.com;
location / {
proxy_pass http://web_app:8000;
proxy_redirect off;
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;
}
}
server {
listen 443 ssl;
server_name yyyy.com;
location / {
proxy_pass http://api_backend:5000;
proxy_redirect off;
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;
}
}
Однако я получаю ошибку шлюза 502 nginx для api.
И с последним решением мне пришлось изменить порт одного из api на 444 с тех пор, как я docker-compose up
Я получаю port 443 is already in use
ошибка.
server {
listen 444 ssl;
server_name yyyy.com;
location / {
proxy_pass http://api_backend:5000;
proxy_redirect off;
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;
}
}
Любые идеи или способы, которыми я могу решить проблему наличия двух процессов nginx на одном сервере?
Примечание. Мой DNS настроен на перенаправление на тот же IP-адрес.
Я также пробовал следовать этот но безрезультатно. По-прежнему та же ошибка, что и выше.