Logo

dev-resources.site

for different kinds of informations.

Top 25 Kafka interview questions

Published at
10/9/2023
Categories
java
kafka
interview
questions
Author
fromfullstack
Categories
4 categories in total
java
open
kafka
open
interview
open
questions
open
Author
13 person written this
fromfullstack
open
Top 25 Kafka interview questions

1. What is Apache Kafka and why is it used?

Apache Kafka is a distributed streaming platform used for building real-time data pipelines and streaming applications.

2. How does Kafka differ from traditional messaging systems?

Kafka is designed for fault tolerance, high throughput, and scalability, unlike traditional messaging systems that may not handle large data streams efficiently.

3. What are Producers and Consumers in Kafka?

Producers publish messages to Kafka topics. Consumers read messages from topics.

// Producer
producer.send(new ProducerRecord<String, String>("topic", "key", "value"));
// Consumer
consumer.subscribe(Arrays.asList("topic"));
Enter fullscreen mode Exit fullscreen mode

4. What is a Kafka Topic?

A Topic is a category to which records are published by producers and from which records are consumed by consumers.

kafka-topics.sh --create --topic my_topic --bootstrap-server localhost:9092
Enter fullscreen mode Exit fullscreen mode

5. How does Kafka ensure durability and fault-tolerance?

Kafka replicates data across multiple brokers. Consumers read from leader replicas, and follower replicas synchronize data.

6. What is a Kafka Partition?

Partitions allow Kafka to horizontally scale as each partition can be hosted on a different server.

7. What is Zookeeperโ€™s role in a Kafka ecosystem?

Zookeeper manages brokers, maintains metadata, and helps in leader election for partitions.

8. How can you secure Kafka?

Kafka can be secured using SSL for encryption, SASL for authentication, and ACLs for authorization.

9. What is Kafka Streams?

Kafka Streams is a client library for building real-time, highly scalable, fault-tolerant stream processing applications.

KStream<String, String> stream = builder.stream(โ€œinput-topicโ€);
stream.to(โ€œoutput-topicโ€);
Enter fullscreen mode Exit fullscreen mode

10. What are some use-cases for Kafka?

Kafka is used for real-time analytics, data lakes, aggregating data from different sources, and acting as a buffer to handle burst data loads.

11. How do you integrate Kafka with Spring Boot?

You can use the Spring Kafka library, which provides @KafkaListener for consumers and KafkaTemplate for producers.

@KafkaListener(topics = โ€œmyTopicโ€)
public void listen(String message) {
    // Handle message
}
Enter fullscreen mode Exit fullscreen mode

12. How do you send a message to a Kafka topic using Spring Kafka?

Use KafkaTemplate to send messages.

kafkaTemplate.send("myTopic", "myMessage");
Enter fullscreen mode Exit fullscreen mode

13. How do you consume messages from a Kafka topic in Spring?

Use the @KafkaListener annotation to mark a method as a Kafka message consumer.

@KafkaListener(topics = โ€œmyTopicโ€)
public void consume(String message) {
    // Process message
}
Enter fullscreen mode Exit fullscreen mode

14. How do you handle message deserialization errors in Spring Kafka?

Use the ErrorHandlingDeserializer to wrap the actual deserializer and catch deserialization errors.

15. How do you ensure ordered message processing in Spring Kafka?

Set the concurrency property of @KafkaListener to 1 to ensure single-threaded consumption for each partition.

@KafkaListener(topics = โ€œmyTopicโ€, concurrency = โ€œ1โ€)
Enter fullscreen mode Exit fullscreen mode

16. How do you batch-process messages from Kafka in Spring?

Use the @KafkaListener annotation with the batchListener property set to true.

@KafkaListener(topics = โ€œmyTopicโ€, batchListener = true)
public void consume(List<String> messages) {
    // Process messages
}
Enter fullscreen mode Exit fullscreen mode

17. How do you filter messages in Spring Kafka?

Implement a RecordFilterStrategy to filter out unwanted records before they reach the @KafkaListener.

Create a class that implements RecordFilterStrategy:

import org.apache.kafka.clients.consumer.ConsumerRecord;
import org.springframework.kafka.listener.adapter.RecordFilterStrategy;

public class MyRecordFilterStrategy implements RecordFilterStrategy<String, String> {

    @Override
    public boolean filter(ConsumerRecord<String, String> consumerRecord) {
        // Return true to filter out the record, false to include it
        return !consumerRecord.value().contains("important");
    }
}
Enter fullscreen mode Exit fullscreen mode

Now, configure your ConcurrentKafkaListenerContainerFactory to use this filter:

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.kafka.config.ConcurrentKafkaListenerContainerFactory;
import org.springframework.kafka.core.ConsumerFactory;

@Configuration
public class KafkaConsumerConfig {

    @Bean
    public ConcurrentKafkaListenerContainerFactory<String, String> kafkaListenerContainerFactory(
    ConsumerFactory<String, String> consumerFactory) {
        ConcurrentKafkaListenerContainerFactory<String, String> factory = new ConcurrentKafkaListenerContainerFactory<>();
        factory.setConsumerFactory(consumerFactory);
        factory.setRecordFilterStrategy(new MyRecordFilterStrategy());
        return factory;
    }
}
Enter fullscreen mode Exit fullscreen mode

Finally, use the @KafkaListener annotation to consume messages:

import org.springframework.kafka.annotation.KafkaListener;
import org.springframework.stereotype.Service;

@Service
public class MyKafkaConsumer {

    @KafkaListener(topics = "myTopic")
    public void consume(String message) {
        System.out.println("Consumed message: " + message);
    }
}
Enter fullscreen mode Exit fullscreen mode

18. How do you handle retries for message processing in Spring Kafka?

Configure a SeekToCurrentErrorHandler or implement a custom error handler to manage retries.

19. How can you produce and consume Avro messages in Spring Kafka?

Use the Apache Avro serializer and deserializer along with Spring Kafkaโ€™s KafkaTemplate and @KafkaListener.

20. How do you secure Kafka communication in a Spring application?

Configure SSL properties in the application.yml or application.properties file for secure communication.

spring.kafka.properties.security.protocol: SSL

21. What are the key differences between Spring AMQP and Spring Pub-Sub?

Spring AMQP is based on the AMQP protocol and is often used with RabbitMQ. It supports complex routing and is suitable for enterprise-level applications. Spring Pub-Sub is generally used with messaging systems like Kafka and is more geared towards high-throughput data streaming.

22. How do message delivery semantics differ between Spring AMQP and Spring Pub-Sub?

Spring AMQP provides more granular control over message acknowledgment and transactions. Spring Pub-Sub, especially with Kafka, focuses on high-throughput and allows at-least-once, at-most-once, and exactly-once semantics.

Configure the producer for exactly-once semantics by setting the transactional.id and acks properties:

import org.apache.kafka.clients.producer.KafkaProducer;
import org.apache.kafka.clients.producer.Producer;
import org.apache.kafka.clients.producer.ProducerConfig;
import org.apache.kafka.clients.producer.ProducerRecord;

import java.util.Properties;

public class ExactlyOnceProducer {
    public static void main(String[] args) {
        Properties props = new Properties();
        props.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG, "localhost:9092");
        props.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, "org.apache.kafka.common.serialization.StringSerializer");
        props.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, "org.apache.kafka.common.serialization.StringSerializer");
        props.put(ProducerConfig.TRANSACTIONAL_ID_CONFIG, "my-transactional-id");
        props.put(ProducerConfig.ACKS_CONFIG, "all");

        Producer<String, String> producer = new KafkaProducer<>(props);
        producer.initTransactions();

        try {
            producer.beginTransaction();
            for (int i = 0; i < 100; i++) {
                producer.send(new ProducerRecord<>("my-topic", Integer.toString(i), Integer.toString(i)));
            }
            producer.commitTransaction();
        } catch (Exception e) {
            producer.abortTransaction();
        }
        producer.close();
    }
}
Enter fullscreen mode Exit fullscreen mode

Configure the consumer to read committed messages:

import org.apache.kafka.clients.consumer.Consumer;
import org.apache.kafka.clients.consumer.ConsumerConfig;
import org.apache.kafka.clients.consumer.ConsumerRecords;
import org.apache.kafka.clients.consumer.KafkaConsumer;

import java.time.Duration;
import java.util.Collections;
import java.util.Properties;

public class ExactlyOnceConsumer {
    public static void main(String[] args) {
        Properties props = new Properties();
        props.put(ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG, "localhost:9092");
        props.put(ConsumerConfig.GROUP_ID_CONFIG, "my-group");
        props.put(ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG, "org.apache.kafka.common.serialization.StringDeserializer");
        props.put(ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG, "org.apache.kafka.common.serialization.StringDeserializer");
        props.put(ConsumerConfig.ISOLATION_LEVEL_CONFIG, "read_committed");

        Consumer<String, String> consumer = new KafkaConsumer<>(props);
        consumer.subscribe(Collections.singletonList("my-topic"));

        while (true) {
            ConsumerRecords<String, String> records = consumer.poll(Duration.ofMillis(100));
            records.forEach(record -> {
                System.out.printf("Consumed record with key %s and value %s%n", record.key(), record.value());
            });
        }
    }
}
Enter fullscreen mode Exit fullscreen mode

23. How do you handle message ordering in Spring AMQP and Spring Pub-Sub?

In Spring AMQP, message ordering is generally maintained within a single queue. In Spring Pub-Sub with Kafka, message ordering is maintained within a partition.

24. How do you implement dead-letter queues in Spring AMQP and Spring Pub-Sub?

Spring AMQP has built-in support for dead-letter exchanges and queues. In Spring Pub-Sub with Kafka, youโ€™d typically use a separate topic as a dead-letter queue.

Consumer Configuration

@KafkaListener(topics = "my-topic", errorHandler = "myErrorHandler")
public void listen(String message) {
    // Process message or throw an exception
}

@Bean
public KafkaTemplate<String, String> kafkaTemplate() {
    return new KafkaTemplate<>(producerFactory());
}

@Bean
public ProducerFactory<String, String> producerFactory() {
    // Configure producer factory
}

@Bean
public MyErrorHandler myErrorHandler(KafkaTemplate<String, String> template) {
    return new MyErrorHandler(template);
}
Enter fullscreen mode Exit fullscreen mode

Custom Error Handler

public class MyErrorHandler implements ErrorHandler {
    private final KafkaTemplate<String, String> template;

    public MyErrorHandler(KafkaTemplate<String, String> template) {
        this.template = template;
    }

    @Override
    public void handle(Exception thrownException, ConsumerRecord<?, ?> record) {
        template.send("my-dead-letter-topic", record.key().toString(), record.value().toString());
    }
}
Enter fullscreen mode Exit fullscreen mode

25. How do Spring AMQP and Spring Pub-Sub handle message filtering?

Spring AMQP supports various routing options including direct, topic, fanout, and headers for message filtering. Spring Pub-Sub with Kafka generally relies on consumer logic for filtering or uses Kafka Streams for more complex scenarios.

In the ever-evolving landscape of backend engineering, Apache Kafka stands as a beacon for real-time data processing and streaming. As Java backend engineers, understanding Kafka is not just a skill but a necessity in todayโ€™s data-driven world. From the simplicity of producing and consuming messages to the complexities of ensuring data durability and fault tolerance, Kafka offers a robust platform for scalable applications. As we continue to explore the depths of real-time data streaming, may our understanding of Kafka deepen, and our applications become more resilient. Until next time, keep streaming and stay curious!

๐Ÿ—จ๏ธ๐Ÿ’ก Join the Conversation! Share Your Thoughts Below.

๐Ÿ—ฃ๏ธ Your opinion matters! We're eager to hear your take on this topic. What are your thoughts, experiences, or questions related to what you've just read? Don't hold backโ€”let's dive into a lively discussion!

Enjoyed this Article?

๐Ÿ’– React: Click the heart icon to show your appreciation and help others discover this content too!

๐Ÿ”” Follow: Stay updated with the latest insights, tips, and trends by subscribing to our profile. Don't miss out on future articles!

๐Ÿš€ Share: Spread the knowledge! Share this article with your network and help us reach a wider audience.

Your engagement is what keeps our community thriving. Thank you for being a part of it!

questions Article's
30 articles in total
Favicon
10 Must-Know Software Testing Interview Questions
Favicon
How does Optional.ifPresent() differ from Optional.orElse()?
Favicon
10 questions developers should ask our self
Favicon
DSA: Array - questions
Favicon
DSA: LinkedList questions
Favicon
DSA: Stack - Questions
Favicon
How to Build an Effective Study Space for IT Certification Preparation: A BCS Business Analysis (BAPv5) Approach
Favicon
Why do I get so many followers on this platform?
Favicon
The Ultimate 2024 Adobe AD0-E555 Exam Question Set for Confident Preparation
Favicon
How to change the redirect URL when changing a user's email in Supabase?
Favicon
Figure out gfg IDLE
Favicon
When "The Best" isn't good enough
Favicon
20 Best Questions to Ask Yourself for Self Growth
Favicon
How to ask better questions?
Favicon
Join Our Organisation
Favicon
How do animation libraries affect SEO in the Next JS?
Favicon
Choosing right tech stack
Favicon
Frontend Fundamentals: Top 10 Interview Questions and In-Depth Answers for Every Developer
Favicon
Top 11 Microprocessor Interview Questions and Answers
Favicon
What should I do?
Favicon
Master Your Success Journey with Pass4success SAP C_S43_2022 Exam Prep
Favicon
Can anyone recommend a modern CSS course?
Favicon
Creating Smart Questions with NestJS and OpenAI
Favicon
111+ Interview Questions - Flutter
Favicon
How to Structure your Resume After your First Job
Favicon
Top 25 Kafka interview questions
Favicon
Top 10 Java interview questions
Favicon
Getting an issue with the (!) mark after the domain name
Favicon
101 questions for python developer
Favicon
google chrome pdf extension

Featured ones: