Добрый день. Накидайте варианты, пжлст, как можно имплиментировать TTL для

прочтения сообщения из топика. Например, есть сообщение в топике, у него в заголовке (или пейлоаде) есть временная метка. Есть ли механизм, который позволит законсюмить данное сообщение через n милисекунд (например, через 10 секунд) относительно временной метки ?

10 ответов

18 просмотров

у консумера есть методы pause / resume. они позволяют остановить потребление сообщений из партиции. используя эти два примитива можно построить алгоритм, который удовлетворит задаче

D.P.- Автор вопроса
Sergio 🤠
у консумера есть методы pause / resume. они позвол...

Все-таки консюмер апи. @javaguy спасибо за направление, буду копать.

D.P.- Автор вопроса
D.P.
Все-таки консюмер апи. @javaguy спасибо за направл...

консюмер апи не предполагает нигде задержку

Либо как писали выше, с помощью pause/resume, либо на уровне приложения каким-то образом «усыплять» поток потребителя, помня только о конфигурации consumer-а, чтобы это время сна не повышало тайм-аут, с который consumer делает poll, чтобы не произошло ребалансировки. Мы в своё время делали это на уровне приложения

D.P.- Автор вопроса
Anastasiya
Либо как писали выше, с помощью pause/resume, либо...

@merenaas Спасибо за отклик. Про интервал и ребалансировку - все так, логично. Если не сравнивать интервал времни паузы, интервал пола и хартбит консюмера - можно нарваться на ребалнсировку. Хочу еще раз проговорить: если правильно понимаю Вашу идею, то в потоке, где полим, делать pause на опред интервал, а потом resume? Все руками, верно?

D.P.- Автор вопроса
Anastasiya
Либо как писали выше, с помощью pause/resume, либо...

Еще вопрос: Вы полили батчем или по одной записи?

D.P.
@merenaas Спасибо за отклик. Про интервал и ребала...

Не уверена, что это будет правильно работать, если это делать в одном потоке. Мы усыпляли консьюмеров по какому-то событию извне. Может быть, лучше действительно на poll генерить некоторое событие, на которое будет подписан класс-держатель консьюмеров, который будет усыплять тех, кого необходимо(пишу на Java, отсюда эти ООП заморочки)

D.P.
Еще вопрос: Вы полили батчем или по одной записи?

Батчем, но у нас над Kafka-client ещё обёртка Spring

D.P.- Автор вопроса
Anastasiya
Батчем, но у нас над Kafka-client ещё обёртка Spri...

Spring оборачивает консюмер апи и ничего нового не добавляет. Ок, более-менее понятно. Спасибо

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

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

Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
всем привет помогите пожалуйста используя CDN (GCP) у игроков из вьетнама загружается конфиг (размер 999 bytes) загружается 5 и более минут н а других CDN сервисах такой пробл...
Andrew Krw.
1
Добрый день. Мне посоветовали обратиться к вам в чат за помощью. Ситуация описана на скрине. Как мне сказали, мне на бота навесили флудвейт. Есть ли возможность снять его ра...
OVERLINK
7
Просто по очереди выпиливаешь на ручной маппинг? По методу за раз
Andrii Kurdiumov
7
)) может, нужно поправить? )) 2. Ребята, нам нужно, чтобы сообщения из Инстаграм приходили в ОДУ. Какое приложение посоветуете?
Alexander Sharoiko MSE / Александр Шаройко
1
Я правильно понимаю что нет способов получить список ожидающих заявок на вступление в группу с помощью бота из mtproto?
Шамиль Прилов
2
Приветствую. А не подскажете какие ограничения есть на использования api метода setMyName ? Несколько раз сменил имя бота и получил бан на 2 месяца на смену имени.
Slick Slack
8
И? Все равно глазами проверять надо каждое поле
Andrii Kurdiumov
4
Всем привет! Взялся портировать модули на 18 версию, лезет _logger.log(log_level, 'no translation language detected, skipping translation %s', frame, stack_info=True) А чт...
Max Lit
3
Ну есть у нас десяток компаний которым надо. Остальным то зачем?
Andrii Kurdiumov
4
Карта сайта