Sobes.tech
Back to questions
Junior — Middle
59

Каким образом топики в Kafka взаимодействуют с подписчиками и как осуществляется обмен сообщениями между ними?

Answer from AI

sobes.tech AI

В Kafka топики служат каналами для обмена сообщениями. Продюсеры публикуют сообщения в топики, а подписчики (консьюмеры) читают эти сообщения. Каждый топик разбит на партиции, что позволяет масштабировать обработку.

Подписчики могут быть организованы в группы консьюмеров. Каждое сообщение из партиции доставляется только одному консьюмеру в группе, что обеспечивает балансировку нагрузки. Обмен сообщениями происходит асинхронно: продюсер отправляет сообщение в топик, Kafka сохраняет его, а консьюмеры считывают по своему графику.

Пример на Java с использованием Kafka Consumer:

Properties props = new Properties();
props.put("bootstrap.servers", "localhost:9092");
props.put("group.id", "my-group");
props.put("key.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");
props.put("value.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");

KafkaConsumer<String, String> consumer = new KafkaConsumer<>(props);
consumer.subscribe(Arrays.asList("my-topic"));

while (true) {
    ConsumerRecords<String, String> records = consumer.poll(Duration.ofMillis(100));
    for (ConsumerRecord<String, String> record : records) {
        System.out.printf("Received message: key = %s, value = %s, offset = %d\n", record.key(), record.value(), record.offset());
    }
}

Таким образом, топики и подписчики обеспечивают эффективный и масштабируемый обмен сообщениями в Kafka.