Вопрос по spring-kafka: 1. Топики создаются и удаляются динамически 2. Слушателей (или

консюмеров) должно быть несколько (в несколько потоков, в один не вывозит)
3. Порядок сообщений важен в пределах топика

Как это правильно сделать? Хотелось бы создать пул контейнеров слушателей или консюмеров, и динамически подписывать их на топик и отписывать от них.
Текущее решение пока такое — создавать слушателей с помощью фабрики с concurrency > 1, слушатели подписываются на паттерн имени топика, в конфиге контейнера выставляется metadata.max.age.ms в несколько секунд. Но это решение выглядит не очень производительным и надёжным

1 ответов

12 просмотров
Alexey-Kuzin Автор вопроса

Я снова выхожу на связь. Если задавать слушателей через @KafkaListener с подпиской на топики по префиксу и ставить в factory бине concurrency с одной группой на всех консьюмеров, то происходит следующая вещь — в каждый момент работает только один консьюмер, а другие простаивают, причём в логах есть такие ошибки Commit cannot be completed since the group has already rebalanced and assigned the partitions to another member. This means that the time between subsequent calls to poll() was longer than the configured max.poll.interval.ms, which typically implies t hat the poll loop is spending too much time message processing. You can address this either by increasing max.poll.interval.ms or by reducing the maximum size of batches returned in poll() with max.poll.records.

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

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

Объясните, пожалуйста, почему компилятор ругается на использование в условии неинициализированной переменной: int x; Task.Run(async () => { x = await somefunc(); }).Wait...
Александр
5
Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
Всем привет. Ребята, подскажите, пожалуйста. у ботов есть ограничение на отправку сообщений - 30 сообщений в секунду, эти ограничения накладываются на все сообщения? или на со...
Artem Stormageddon
4
Блин, ребята, сори за тупые вопросы. А можно ли как-то открыть вебапку по нажатию на кнопку в меню(которое появляется слева, команды)?
Artem Stormageddon
3
Коллеги, может знает кто, можно ли цвет бейджа счётчика в BackendMenu менять без бубнов?
Alex Blaze
3
Привет!) Кто как юзает переменные в строках?) Чисто ради интереса Вот так: echo "У меня {$bananasAmount} бананов"; Или вот так: echo "У меня ${bananasAmount} бананов";
Виталий
3
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
разработчик ботов скидывает портфолио, боты которые он уже создал. А вот как узнать что это именно он их создал?
Gosudar
4
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
13
Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
Карта сайта