Есть допустим микруха Идет запрос к одному из сервисов, он в

свою очередь порождает запросы к другим N сервисам

Но вот в одном из них что-то пошло не так
Соответственно нужно ролбекнуть эти запросы

Но тут возникает вопрос
Чтобы всё вернуть как было, нужно дождаться пока все запросы к N вернут результат. Ну чтобы знать что и где откатывать. А это может быть долго.

Ещё вообще не желательно ждать пока чёт там в N сервисах выполнится. Но к сожалению НАДА.

В общем чё планирую сделать.
Разделить запросы на группы: такие, не такие, совсем не такие.
1) апдейиты всяких счетчиков и прочих некритичных данных
2) апдейты критичных данных
3) создание новых записей

(1) ваще не ждать как они завершатся, путь висят в очереди с бесконечным TTL
за (2) и (3) следить, и если чёт факапится, то откатываться

Всё ли правильно? Чё ещё порекомендуете?

2 ответов

6 просмотров

Сильно зависит от механизма роллбека (как он вообще в вашем решении устроен). Я бы попробовал с мессадж брокером поиграться - храня состояние и исторю какого-то ентити (чье состояние надо откатить) в базе. Это вот совсем первые мысли

SAGA pattern и все вокруг, Event Sourcing, CQRS

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

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

Ребята, всем привет. Подскажите, пожалуйста, можно ли как-то через бота понять, что этого бота добавили в группу\канал и выдали ему права администратора?
Artem Stormageddon
9
Это переведённый текст с английского. Я не говорю на русском, но могу использовать переводчик Телеграм. Приветствую! Я начинающий веб-разработчик и все еще учусь. В настояще...
𐩱𐩪𐩣𐩱𐩲𐩺𐩡
2
А не хотим ли мы развлечься? 😉 Но так чтобы с пользой для наших профессиональных навыков?? 👨‍🎓👩‍🎓 Предлагаю на октябрь запланировать тестовый запуск новой командной игры "Игр...
Andrii Kurdiumov
2
Привет всем! Почему этот код не срабатывает при добавлении или удалении пользователя из чата? bot.on('chat_member', async (ctx) => { console.log(ctx); }) bot.launch({allo...
Alexander
5
у кого сколько оперативы на базе данных ?
АДИЛЬБЕК
4
Через бот апи возможно получить ID стикерпака? Не ссылку.
Vexylon [АФК до 09.09]
5
Привет Хочу сделать аналог iCloud’а для своих проектов, чтобы пользовательская информация хранилась в облаке, была доступна во всех сервисах, её можно было подсасывать везде)...
Виталий
9
В тг можно спарсить всех кто пишет в группе? Если список участников скрыт
S
3
код Event::listen('cms.page.display', function (&$content, $slug, $page, $html) { if (is_object($content)) { dump($content); } else { dump($s...
Point 111
3
Доброе утро, мультиязычные сайты делал кто-нибудь? Какие подводные камни? Нужно чего нибудь допом ставить? Как поступить? В теории сделать две папки ru en и туда кидать страни...
Racoon Mitya
2
Карта сайта