Integración de Kafka para notificaciones en un proyecto Astro y Next.js
- Daniel J. Saldaña
- 16 de julio de 2024
-
-
- Puntuación de feedback
-
En este post, te mostraré cómo hemos integrado un sistema de notificaciones usando Kafka en un proyecto que utiliza Astro para el frontend y Next.js para el backend. El objetivo es publicar un mensaje en un tópico de Kafka cada vez que se genera un post en formato .md
y notificar a los usuarios en su panel de usuario sobre las últimas novedades. A continuación, se explica el proceso de cómo y cuándo se publica un mensaje en el tópico de Kafka.
Proceso de compilación en Astro
-
Configurar variables de entorno: Utilizamos
dotenv
para cargar las variables de entorno necesarias para conectar con Kafka y Azure Storage. -
Configuración de Kafka: Configuramos el cliente de Kafka con autenticación SSL y SASL, y creamos un productor para enviar mensajes.
-
Registrar el esquema en el Schema Registry: Utilizamos
SchemaRegistry
de Confluent para registrar el esquema Avro que define la estructura de los mensajes de los posts. -
Procesar y subir los posts: Leemos los archivos
.md
del directorio de posts, extraemos los metadatos usandogray-matter
, y verificamos si la entidad ya existe en Azure Table Storage. Si la entidad no existe, publicamos un mensaje en el tópico de Kafka con la información del post.
Script de compilación
Este script se ejecuta durante el proceso de compilación de la web en Astro, cuando se va a desplegar. Aquí se describe cómo se procesa cada post y se publica en Kafka si no existe en Azure Table Storage.
¿Cuándo se publica en el tópico de Kafka?
El mensaje se publica en el tópico de Kafka solo si el post no existe ya en Azure Table Storage. Este es el proceso detallado:
-
Lectura de Archivos: Se leen todos los archivos
.md
del directorio de posts. -
Extracción de Metadatos: Para cada archivo
.md
, se extraen los metadatos usandogray-matter
. -
Verificación en Azure Table Storage: Se verifica si una entidad con la misma
PartitionKey
yRowKey
ya existe en Azure Table Storage. -
Publicación en Kafka: Si la entidad no existe, se construye un mensaje con los metadatos del post, se codifica usando el esquema registrado en Confluent Schema Registry y se publica en el tópico de Kafka.
-
Creación de la Entidad: Después de publicar el mensaje, se crea la entidad en Azure Table Storage.
Este enfoque asegura que solo los posts nuevos se publiquen en el tópico de Kafka, evitando duplicados.
Endpoint en Next.js para obtener notificaciones
En el backend, hemos creado un endpoint en Next.js que consume los mensajes del tópico de Kafka y los devuelve ordenados por fecha.
Componente de React para el frontend en Astro
Finalmente, en el frontend de Astro, hemos creado un componente en React que se encarga de mostrar las notificaciones a los usuarios cuando inician sesión.
Con esta configuración, logramos notificar a los usuarios sobre las últimas novedades cada vez que se genera un nuevo post en formato .md
, usando Kafka como sistema de mensajería. Esta solución proporciona una manera eficiente y escalable de manejar las notificaciones en tiempo real.