Всем привет. Есть спринг-бут приложение без клаудов-стримов и прочего. Есть

один топик. Партиций условно 10. Пишут в топик 1-2-3 сервиса, но много. Лиснеров по количеству партиций, 10 подов. Каждый инстанс там по своей партиции взял и разгребает. Процессинг при разгребании чуть сложный, потому приличный лаг накопился. В какую сторону делать "оптимайзинг"? Я так полагаю у спринга тюнить concurrency не следует, если консумеров столько же, сколько партиций?

3 ответов

12 просмотров

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

Pavel-Ryzhkov Автор вопроса
George Bolshakov
направлений несколько 1) увеличение кол-ва партици...

Благодарю за развёрнутый ответ. 1 - там топик живёт сутки, событий в нём много, ребалансировка полагаю займёт продолжительное время, потому пока откинул данный вариант. 2,3 - в этом направлении и предполагаю. Там события такие, что не сильно страшно перечитать в случае чего или потерять парочку. Потому склоняемся к batch и какой-нибудь auto-commit-offset по времени

Pavel Ryzhkov
Благодарю за развёрнутый ответ. 1 - там топик живё...

увеличение партиций не приводит к ребалансу сообщений в существующих партициях, просто новые партиции начнут заполняться новыми сообщениями и подравняются когда пройдет полный цикл по ретеншену

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

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

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