172 похожих чатов

Подскажите по такой задаче. У меня есть N подов с моим

REST сервисом. У каждого есть внутри ограничение конкуретности запросов.
Например каждый может делать одновременно 5 запросов (они разные по длительности).
Если он "занят" то он отвечает http code 429.

Я попробовал прикрыть это обычным round robin load balancer - работает плохо. Постоянно шлёт на незанятые (понятно что ему инфы мало).

Как бы это решить красивее?

Мне в голову только приходит дополнительно поставить какой то умный proxy (haproxy?)
Который бы умел делать это умнее. (я могу ещё ручку впилить которая скажет свободен или нет со стороны pod)

5 ответов

3 просмотра

может асинхронности добавите

engelbart- Автор вопроса
Sergei Monakhov
может асинхронности добавите

Ну я могу на клиента, но это же не изменит того что он будет получать 429 и одновременно с этим у меня будут недозагруженные инстансы которые могли бы обработать. Мне так не особенно хочется.

engelbart
Ну я могу на клиента, но это же не изменит того чт...

так вы можете сделать сервис асинхронным и не отдавать 429, или повесьте частый readinessProbe, но гарантий тоже не будет, дальше сервисмешы и энвой

умный энвой и пускай ему в реальном времени бекендыы сами что надо сообщают

nginx proxy_next_upstream error timeout http_429;

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

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

А случайно нет ли в паскале штатной возможности передать указатель и количество туда где array of в качестве аргумента?
zamtmn
25
Почему Telegram пишет, что объект media не найден, хотя на самом деле я его передаю? Делаю на urllib, без зависимостей, так надо. Вызываю метод sendMediaGroup с таким JSON: ...
Alexey S
1
Anyone here suffers from unexplained aural migraines, who would be up for talking for a bit? Doesn't *have* to be aural, but I am not asking about headaches, I mean actual mi...
Martin Rys
58
Ну раз я пока тут, задам пару глупых вопросов. Зачем писать на ассемблере если компилятор довольно умный, а ассемблер много времени занимает? В каких прикладных задачах сейчас...
Максим Рябцев
20
Я тут за тем, чтобы задать вопрос, так как не знаю ассемблер, учу с/с++. Короче, насколько дорога операция перехода в функцию при ее вызове? Дело в том, что в с++ есть макросы...
Максим Рябцев
12
Привет, нужен совет старших товарищей. Есть глобальная переменная var DefaultDataFolder:string; инициализируем DefaultDataFolder:='a:\_OUT\'; есть примитивная процедур...
Max Otto
14
А какие чаты вообще в ходу? Auto aim? И что еше
do you think you're better off alone? А
13
hello friends. Do you know how can I learn getx? I have a software project that I should deliver it up to 5 weeks later and I need to learn firebase too. I will be thankfull
AmirHossein Razavi
15
Доброе время суток! у меня тут иноды закончились. и понял почему по сути кстит, я периодически очищаю постгрес и сентри контайнер: postgres=# DELETE FROM nodestore_node WHER...
Юсиф Насиров
9
Вопрос. Теоретический. Есть список команд. Команды отправляю в обработку некой функции, по очереди. Разные команды могут давать разные результаты после обработки. В зависимос...
Serjone
7
Карта сайта