Вопрос к знатокам, будет ли данное нормально балансить, если одна

нода "отлетит"? будет ли nginx ходить в мёртвую ноду при такой конфигурации?

upstream gate {
server gate1-test.ru:443 max_fails=1 fail_timeout=1s;
server gate2-test.ru:443 max_fails=1 fail_timeout=1s;
server gate3-test.ru:443 max_fails=1 fail_timeout=1s;
server gate4-test.ru:443 max_fails=1 fail_timeout=1s;
server {
listen 443;
server_name gate-balancing.ru;

proxy_ssl_certificate /nginx/cert/cert.cer;
proxy_ssl_certificate_key /nginx/cert/key.key;

proxy_connect_timeout 60s;
proxy_read_timeout 60s;

access_log /nginx/log/access.log main;
error_log /nginx/log/error.log error;

location / {
proxy_pass https://gate;

proxy_ssl_certificate /nginx/cert/client.cer;
proxy_ssl_certificate_key /nginx/cert/client.key;

}
}

7 ответов

16 просмотров
Илья- Автор вопроса

@kiosaku ping)) доброго дня)

Будет, но не очень. max_fails задаёт число неудачных попыток работы с сервером, которые должны произойти в течение времени, заданного параметром fail_timeout, чтобы сервер считался недоступным на период времени, также заданный параметром fail_timeout. Соотвественно если за 1s будет 1 неудачная попытка, то сервер на 1s пометится как недоступный. Ну и следует иметь в виду, что это пассивные проверки, nginx не проверяет доступность серверов, он ориентриуется на его ответы.

Илья- Автор вопроса

а, тут понял, спасибо, а по опыту fail_timeout на сколько лучше ставить в нагруженной системе?

Илья
а, тут понял, спасибо, а по опыту fail_timeout на ...

Надо тестировать и самому разбираться. Мне подходят max_fails = 5 и fail_timeout = 60s Но всё сильно зависит от траффика, окружения и требований. Поднимите тестовую среду, запустите ab или yandex.tank и шатайте бэки, тогда точно будет ясно.

Илья- Автор вопроса
Panurg Panurg
Надо тестировать и самому разбираться. Мне подходя...

да я обычно так и делаю))) без тестирования никуда ) но помнится ошибки у меня всё же проскакивали, когда я 1000 запросов зарядил, по 4 запроса в секунду

Илья
да я обычно так и делаю))) без тестирования никуд...

Они и будут проскакивать. Это ПАССИВНЫЕ проверки. Пока запрос клиента не попадёт на сломанный бэк и nginx не увидит, что бэк не может ответить, он не исключит его.

Илья- Автор вопроса

Похожие вопросы

Обсуждают сегодня

1. https://www.kaggle.com/code/ahmadrezagholami2001/housing-estimation-linear-regression 2. https://www.kaggle.com/code/ahmadrezagholami2001/uncovering-quality-in-wines-logis...
Ahmadreza
1
Hi! Could you please upvote my new notebook? thanks a lot. https://www.kaggle.com/code/melissamonfared/anime-character-generation-dsgan-gan
məru
4
upvote plz https://www.kaggle.com/code/bassetkerouche/swapping-face?scriptVersionId=207300096
benkerrouche Statoinary
1
-- Привет всем. -- Есть csv, проблема в том что он содержит очень много повторов по столбцам и по строкам. -- Решил перекинуть это в базу данных, чтобы было проще. Но я не ша...
Oleg Ivanov
1
Как считаете - вопрос на собесе: «Как быстрее всего запустить ec2 машину в aws (в чистом аккаунте) и показать вывод от любой команды с нее» не очень ли сложный для условного м...
Sergey
50
Господа, у меня вопрос. Что вообще такое этот ваш data science и data scientists? А то гуглю, а мне какую-то расплывчатую фигню говорят.
Inkosta
44
Исходя из ваших комментариев, получается, что чтобы получить марты в CH из данных в PG, неправильно тянуть сырые данные в CH и там их обрабатывать, лепить справочники и джойни...
unhingedlunatic
42
Hi could you please help me with my two new projects? https://www.kaggle.com/code/hesankazemnia/rice-image-classification-cnn-pytorch https://www.kaggle.com/code/hesankazemnia...
Hesan
6
hi, Can you upvote? https://www.kaggle.com/code/durjoychandrapaul/rag-q-a-system-by-langchain-huggingface-for-pdf?scriptVersionId=204704280
A
1
Could you upvote and comment please? https://www.kaggle.com/code/tatianapetrushkevich/beginner-images https://www.kaggle.com/code/tatianapetrushkevich/python-for-beginners1 ...
Tazziyana
7
Карта сайта