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

Привет всем может есть идеи, а то недавно похожее обдумывал, и

пришел что лучшее решение это когда получил сообщение сделать запрос в 3д парти и положить ид для опроса 3д парти в бд
и сделать воркер который будет poll из базы делать и запрашивать статусы определенное кол-во записей, а то сообщений может быть около тысячи-сотни тысяч
но тут узкое место наша база, так как особо не масштабируется

так вот сама задачка, у нас есть фича отправить сообщение(запрос идет на сервис1), но атачмент к нему обрабатывается от 1 минуты до 1 часа
и вот идея была сделать сервис2(который обрабатывает это в фоне) и дает апи мол создать джобу(пошлет в кафку сообщение)
что бы начать фоновый процесс, и сервис1 будет ждать минуту, если сервис2 успел, то возьмет инфу,если нет то без нее отправил, так вот сама проблема в сервис2
потому что если делать так что делатся Consume и шлется в 3д парти запрос на создание и потом в цикле ожидает когда готово(дергает их апи на проверку) то этот процесс может быть по минут 20 и из-за кафки
остальные сообщения в данной партиции застрянут а могли бы к примеру за 10 сек обработаться.
так вот вопрос, как такое можно обойти?

Сервис скейлится на 20+ инстансов

Ограничения:
rabbitmq и тд нельзя, а то ограничение юзать только кафку

2 ответов

7 просмотров

Лол

Sergei-Valko Автор вопроса
Alexander Luzgarev
Лол

ну вот такие вот ограничения :)

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

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

Такой вопросец - есть функция function MySuperDuperConcat(const a: array of AnsiString): AnsiString; Как мне в её теле сделать вот так? Result:=Concat(a); А не грустный вариан...
notme
15
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
48
type TObj = object procedure Init; virtual; end; TObj1 = object(TObj) procedure Init; override; end; procedure TObj1.Init; begin inherited; end; procedur...
Alexander 👋
29
А чем вам питонисты не угодили?😂
.
79
Можно ли загрузить скрипт py в бота чтобы он работал по нему? как это сделать?
huskadam #RCC Фанат? @hitlerpvp
13
Всем здравствуйте! Я хотел узнать сколько стоит средняя месячная зарплата у Electron js разработчиков? Мне очень это важно и нужно, плиз помогите узнать эту инфу! Для Джунио...
U.K.
10
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
83
А дин типизация это хорошо или плохо?
Alexey
12
Язык Си можно выучить за день? По книжке ANSI C на 230 страниц
Vincent Vegan
29
Hello. Could you please help me with finding all coordinates within a radius using a spatial index, given that I have a table with coordinates? SET @lng = 37.57925; SET @lat ...
Rinchin G
8
Карта сайта