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

Всем привет, есть вопросик по правильной архитектуре сервиса / подходящему

фреймворку

задача такая - нужно время от времени вычитывать из базы список айдишников, а потом с этим списком айдишников ходить в несколько разных систем (HTTP/JDBC) и делать там определенные stateless действия, которые могут быть распараллелены между этими системами.
Условный псевдокод приблизительно какой-то такой:

val ids: List[String] = IndexService.get()
system1.process(ids)
system2.process(ids)
system3.process(ids)
Хочется чтобы systemX.process было параллельно( видимо через Futures?) и легко можно было отслеживать статус каждого процесса (скажем, репортить на API).
Я думаю в сторону Akka, или что-то получше подойдет?

4 ответов

10 просмотров

Можно решить проблему стандартным фьючами, без акки

Я бы сказал, что если параллелизм - ваша основная цель, наиболее точным решением будут какие-то стримы (fs2, akka-streams, cats-iteratees, zio-ztream) С их помощью вы наиболее точно сможете настроить, сколько действий может выполняться одновременно, до какой степени можно нарастить буфер невыполненных задач и т.п.

относительно репорта статуса -- задачи предоставляют какой-то внутренний апи "прогресса", или же надо проверять статус условной фьючи, закончилась или нет?

я такое делаю обычно на акка-стримах

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

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

Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Хотел бы спросить у знающих, правильную ли я выбрал книгу для начала изучения ассемблера Юрова В.И ? Или есть более лучшие книги для начала обучения?
Botsman
31
$params = [ 'formid' => 'feedbackForm', 'formTpl' => '@CODE: <form class="form-validate" data-id="ajax_form"> <fieldset class="margin-bottom-md"> ...
Pathologic
1
Всем привет, подскажите/посоветуйте пожалуйста. Фаердак компоненты, имею одно место где бизнес хочет видеть при открытии формы список всех клиентов, это порядка 30к. Мои дово...
Sasha Sch
8
А как лучше конвертировать физический адрес в виртуальный при маппинге? В случае ядра у меня, например, direct mapping, первые 768МБ я как есть мапплю в higher half, а остальн...
Evg Resh
8
Книга Юрова В.И пойдёт для обучения?
Botsman
24
Всем доброго дня, ребят подскажите пожалуйста, если в курсе по ассемблеру используется MASM32, могу ли я использовать FASM? В чем явная разница и будет ли у меня все работать?
Botsman
17
Где можно найти примеры эффективного "асинхронного" tcp сервера на C? Я видел select, kqueue, poll, epoll и т.д. Ввод-вывод неблокирующий, но обработка клиентов блокирующая
#
10
Hi Everyone! To all Are you Looking for Interview Support at the Lowest Price? Look no further! Then contact us 👉We offer Interview Support :-for a low cost variety of tech...
Rambabu Nallamilli
3
И ещё вопрос: можно ли типа как на дос как-то запариться и с помощью прерываний выводить текст, вместо функции printf ?
НѣкъиⰘижєжєиꙁъвьсєсвѣтьноѣсѣтиѥсть•
34
Карта сайта