Sobes.tech
Назад к вопросам
Junior — Middle
66

Имеете ли вы практический опыт работы с системой обмена сообщениями Kafka?

Компании, где спрашивали
СБЕР Бизнес
Prooftech
СБЕРСБЕР
Акселератор возможностей
ИннотехИннотех
Firecode
Secreate
ГосуслугиГосуслуги
Workme
ОТП БанкОТП Банк
Северсталь-ИфокомСеверсталь-Ифоком

Ответ от нейросети

sobes.tech AI

Да, я имею практический опыт работы с Apache Kafka. Это распределённая платформа обмена сообщениями, которая позволяет публиковать, хранить и обрабатывать потоки данных в реальном времени.

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

Пример простого продюсера на Java:

Properties props = new Properties();
props.put("bootstrap.servers", "localhost:9092");
props.put("key.serializer", "org.apache.kafka.common.serialization.StringSerializer");
props.put("value.serializer", "org.apache.kafka.common.serialization.StringSerializer");

KafkaProducer<String, String> producer = new KafkaProducer<>(props);
producer.send(new ProducerRecord<>("my-topic", "key1", "value1"));
producer.close();

И пример консьюмера:

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(Collections.singletonList("my-topic"));
while (true) {
    ConsumerRecords<String, String> records = consumer.poll(Duration.ofMillis(100));
    for (ConsumerRecord<String, String> record : records) {
        System.out.printf("offset = %d, key = %s, value = %s%n", record.offset(), record.key(), record.value());
    }
}