Configurar y usar Apache Kafka con Spring Boot

May 13 2023
Kafka con bota de resorte
Introducción Apache Kafka es una plataforma de transmisión distribuida de código abierto que maneja la transmisión de datos en tiempo real tolerante a fallas, de alto rendimiento y a gran escala. El sistema se basa en un modelo de publicación-suscripción en el que los productores publican mensajes sobre temas y los consumidores se suscriben a esos temas para consumir los mensajes.
Fuente de imagen

Introducción

Apache Kafka es una plataforma de transmisión distribuida de código abierto que maneja la transmisión de datos en tiempo real tolerante a fallas, de alto rendimiento y a gran escala. El sistema se basa en un modelo de publicación-suscripción en el que los productores publican mensajes sobre temas y los consumidores se suscriben a esos temas para consumir los mensajes. El caso de uso de Apache Kafka se ve en escenarios como análisis en tiempo real, arquitecturas basadas en eventos, agregación de registros, sistemas de mensajería y creación de canalizaciones de datos escalables.

Uso de este documento:

Puede usar este documento para configurar y usar Apache Kafka para producir y consumir mensajes (contenido JSON) en su aplicación de arranque Spring.

requisitos previos

Necesita una buena comprensión de Java, spring-boot, Apache Kafka, maven o Gradle antes de leer este documento; de lo contrario, le sugeriremos que consulte su documentación y guía oficiales.

Instalación

Antes de generar mensajes para los temas de Kafka, debe completar algunos pasos para configurar las dependencias requeridas en su pom.xml (Maven) o build.gradle (proyecto Gradle)

Para experto:

For Gradle 
<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
   <groupId>org.springframework.kafka</groupId>
   <artifactId>spring-kafka</artifactId>
</dependency>

implementation ‘org.springframework.boot:spring-boot-starter’
implementation ‘org.springframework.kafka:spring-kafka’

Configuración

Al configurar las propiedades de Kafka en el archivo Application.properties, también puede tener sus propiedades personalizadas. Especifique los servidores de arranque del servidor Kafka y cualquier propiedad de configuración adicional que necesite, como el ID del grupo de consumidores.

Aplicaciones.propiedades

spring.kafka.bootstrap-servers=<kafka-bootstrap-servers> 
spring.kafka.consumer.group-id=<consumer-group-id>
spring.kafka.producer.key-serializer=org.apache.kafka.common.serialization.StringSerializer
spring.kafka.producer.value-serializer=org.apache.kafka.common.serialization.StringSerializer
spring.kafka.app.topic=<topic-name>


spring.kafka.bootstrap-servers=localhost:9092 
spring.kafka.consumer.group-id=group_category
spring.kafka.producer.key-serializer=org.apache.kafka.common.serialization.StringSerializer
spring.kafka.producer.value-serializer=org.apache.kafka.common.serialization.StringSerializer
spring.kafka.app.topic=my-topic

Un productor de Kafka es un componente que envía mensajes a los temas de Kafka. Publica datos en Kafka, que luego pueden consumir uno o más consumidores de Kafka.

Para crear un productor de Kafka, debe realizar los siguientes pasos:

  1. Configure las propiedades del productor de Kafka: configure las propiedades de configuración necesarias para el productor de Kafka, como los servidores de arranque (direcciones de los agentes de Kafka) y la configuración de serialización. Esto ya lo hemos realizado en el último paso.
  2. Crear un productor de Kafka: Para enviar mensajes a Kafka; puede utilizar la plantilla proporcionada por Spring Kafka. He aquí un ejemplo de un productor simple:
  3. import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.kafka.core.KafkaTemplate;
    import org.springframework.stereotype.Service;
    import org.slf4j.Logger;
    import org.slf4j.LoggerFactory;
    
    @Component
    public class KafkaEventProducer {
     
     private static final Logger logger = LoggerFactory.getLogger(KafkaEventProducer.class);
     
     @Autowired
     private KafkaTemplate<String, String> kafkaTemplate;
     
     public void sendMessage(String topic, String message) {
       logger.info("Producing message [{}]", message);
       kafkaTemplate.send(topic, message);
     }
    }
    

  4. Configure las propiedades del productor de Kafka: Configure las propiedades de Kafka en su archivo application.properties. Especifique los servidores de arranque del servidor Kafka y cualquier propiedad de configuración adicional que necesite para el consumidor.
  5. Cree un oyente consumidor de Kafka: implemente un método en su aplicación al que se llamará cada vez que se reciba un nuevo mensaje de Kafka. Utilice la anotación kafkaListener proporcionada por Spring Kafka.
  6. import org.springframework.kafka.annotation.KafkaListener;
    import org.springframework.stereotype.Component;
    import org.slf4j.Logger;
    import org.slf4j.LoggerFactory;
    
    @Component
    public class KafkaEventConsumer {
    
    private static final Logger logger = LoggerFactory.getLogger(KafkaEventConsumer.class);
    
    @KafkaListener(topics = “<topic-name>”, groupId = “<consumer-group-id>”)
     public void consumeMessage(String message) {
      //Use log
     log.info("Consumed message [{}]", message);
     }
    }
    
    

    @KafkaListener(topics = “${spring.kafka.app.topic}”,groupId= “${spring.kafka.consumer.group-id}”)
    

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class MainApplication {

 @Autowired
 private KafkaEventProducer kafkaEventProducer;

 public static void main(String[] args) {
   SpringApplication.run(MainApplication.class, args);
 }
 
 public void YourMethod() {
 // Send a message using the Kafka producer
 kafkaEventProducer.sendMessage(“<topic-name>”, “Oh Kafka Boy How'z Everything?”);
 }
}

Conclusión

En conclusión, Spring Boot brinda un excelente soporte para integrar Apache Kafka en sus aplicaciones. Con la compatibilidad con Kafka de Spring Boot, puede crear fácilmente productores y consumidores de Kafka, configurar las propiedades de Kafka y manejar el procesamiento de mensajes.
La integración de Spring Boot con Kafka simplifica el desarrollo de aplicaciones basadas en Kafka, proporcionando un mayor nivel de abstracción y reduciendo la cantidad de código repetitivo necesario.

Y antes de ejecutar el código, asegúrese de que el servidor Kafka se esté ejecutando y que se hayan creado los temas.

Nota: Recuerde consultar la documentación oficial de Spring Kafka y explorar los ejemplos de Spring Kafka para comprender mejor las diversas funciones y opciones disponibles para la integración de Kafka en Spring Boot.

¡Gracias!