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

Всем привет! Вопрос по либе pika У меня есть очередь с задачами,

а приложение состоит из мастера и N чайлдов, которым из мастера будут таски назначаться (по одной штуке, до выполнения)
Как мне получить определенное количество тасков из очереди, чтобы распределять их между тредами? Вроде, когда вешаешь на очередь слушателя, он перед выдачей следующего таска ожидает ack/nack предыдущего.
Подтверждением тасков тоже будет заниматься мастер.

P.S. Создавать подключение в каждом треде не вариант, поскольку таски выполняются несколько секунд (то есть требуется частый реконнект или удержание подключения), но у меня есть лимит (на стороне брокера) на количество одновременных коннектов. А тредов заведомо больше

2 ответов

6 просмотров

я правильно понял что у вас типо несколько задач и по сути они логически обьеденены и вас надо чтоб все было ок выполнить пачку функций в правильной последовательности?

Leon- Автор вопроса
Anton
я правильно понял что у вас типо несколько задач ...

Нет, последовательность выполнения любая. Но есть несколько хостов, каждый из которых параллельно выполняет несколько задач. Допустим, у меня 5 хостов, на каждом из которых запущено 5 потоков выполнения. Если каждый поток будет иметь свой коннект к очереди, то это 25 коннектов. А разрешённое количество одновременных подключений к кролю всего 20. Вот у меня задача чтобы с одного хоста было только одно подключение, через которое каждый хост будет распределять задачи между своими тредами. Я, кажется, нашел вариант решения, но займусь им уже только завтра, сейчас спать

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

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

Вопрос по диагностике ошибок (я знаю в чем, в данном конкретном примере, я знаю, как исправить, пример модельный, понятно, что в реальности бывает намного запутаннее). module...
ⰄⰎⰋⰐⰐⰑⰛⰤⰧⰧⰩⰄ ⰊⰑⰁⰓⰡⰛⰦⰕⰫ
10
А чем вам питонисты не угодили?😂
.
79
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
48
Есть предложения, как подобное можно упростить?
Hemul GM
12
type TObj = object procedure Init; virtual; end; TObj1 = object(TObj) procedure Init; override; end; procedure TObj1.Init; begin inherited; end; procedur...
Alexander 👋
29
У меня вопросик назрел. Почему, создав класс без наследования и реализации деструктора Destroy, деструктор не вызывался при free. Потом указал наследование от tobject и overri...
Сергей Бычков
9
@y0zhig @shizzard А можно я опишу цель и может вообще ерланг мне не подходит. На текущий момент как я понимаю у ерланга есть легковесные потоки и задача выполняется в каком т...
Дмитрий Спиридонов
5
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
86
Такой вопросец - есть функция function MySuperDuperConcat(const a: array of AnsiString): AnsiString; Как мне в её теле сделать вот так? Result:=Concat(a); А не грустный вариан...
notme
15
just use free version ?? pycharm has a free version
Fan / Ac
9
Карта сайта