Я видел много статей, в которых они используют Countdownlatch в слушателе Kafka, но я не могу понять, почему он здесь используется. Настраивает ли это количество сообщений, которые слушатель может потреблять одновременно? < /P>
private CountDownLatch eventLatch = new CountDownLatch(1);
@KafkaListener(topics = "${message.topic.name}", containerFactory = "eventKafkaListenerContainerFactory", groupId = "${kafka.consumer.groupId}")
public void eventListener(
@Payload Event event,
@Header(KafkaHeaders.OFFSET) Long offset,
@Header(KafkaHeaders.RECEIVED_PARTITION_ID) int partition,
@Nullable @Header("X-Retry") String retryCountHeader,
Acknowledgment ack
) {
log.info("Received event message: {} from partition : {} and offset : {} ", event, partition, offset);
try {
persistEventToDB(event);
} catch (Exception e) {
log.info("Exception occured : {}", e.getClass().getName());
if (e instanceof DateTimeParseException) {
log.info("Non Recoverable exception , hence sending to DLT without any retry for message : {}", event);
sendToDLT(event, null, false);
} else {
log.info("Sending to DLT for retry as message consumption failed for message {} ", event);
sendToDLT(event, retryCountHeader, true);
}
} finally {
ack.acknowledge();
this.eventLatch.countDown();
}
}
Подробнее здесь: https://stackoverflow.com/questions/732 ... a-listener
Каково использование защелки обратного отсчета у слушателя Kafka? ⇐ JAVA
Программисты JAVA общаются здесь
-
Anonymous
1759289511
Anonymous
Я видел много статей, в которых они используют Countdownlatch в слушателе Kafka, но я не могу понять, почему он здесь используется. Настраивает ли это количество сообщений, которые слушатель может потреблять одновременно? < /P>
private CountDownLatch eventLatch = new CountDownLatch(1);
@KafkaListener(topics = "${message.topic.name}", containerFactory = "eventKafkaListenerContainerFactory", groupId = "${kafka.consumer.groupId}")
public void eventListener(
@Payload Event event,
@Header(KafkaHeaders.OFFSET) Long offset,
@Header(KafkaHeaders.RECEIVED_PARTITION_ID) int partition,
@Nullable @Header("X-Retry") String retryCountHeader,
Acknowledgment ack
) {
log.info("Received event message: {} from partition : {} and offset : {} ", event, partition, offset);
try {
persistEventToDB(event);
} catch (Exception e) {
log.info("Exception occured : {}", e.getClass().getName());
if (e instanceof DateTimeParseException) {
log.info("Non Recoverable exception , hence sending to DLT without any retry for message : {}", event);
sendToDLT(event, null, false);
} else {
log.info("Sending to DLT for retry as message consumption failed for message {} ", event);
sendToDLT(event, retryCountHeader, true);
}
} finally {
ack.acknowledge();
this.eventLatch.countDown();
}
}
Подробнее здесь: [url]https://stackoverflow.com/questions/73279474/what-is-the-use-of-countdown-latch-in-kafka-listener[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия