Compartir a través de


Uso de esquemas JSON con aplicaciones Apache Kafka

Este tutorial le guiará a través de un escenario en el que se usan esquemas JSON para serializar y deserializar eventos mediante el Registro de esquemas de Azure en Event Hubs.

En este caso de uso, una aplicación productora de Kafka utiliza el esquema JSON almacenado en Azure Schema Registry para serializar el evento y publicarlo en un tema/centro de eventos de Kafka en Azure Event Hubs. El consumidor Kafka deserializa los eventos que consume de Event Hubs. Para ello, utiliza el Id. de esquema del evento y el esquema JSON, que se almacena en Azure Schema Registry. Diagrama que muestra la serialización/deserialización del esquema para aplicaciones Kafka que utilizan el esquema JSON.

Requisitos previos

Si es la primera vez que usa Azure Event Hubs, consulte la información general de Event Hubs antes de continuar con este inicio rápido.

Para completar este tutorial de inicio rápido, debe cumplir los siguientes requisitos previos:

Creación de un centro de eventos

Siga las instrucciones del inicio rápido Creación de un espacio de nombres y un centro de eventos de Event Hubs para crear un espacio de nombres de Event Hubs y un centro de eventos. A continuación, para obtener una cadena de conexión al espacio de nombres de Event Hubs, siga las instrucciones que se indican en Obtención de una cadena de conexión.

Anote la siguiente configuración que usará en el inicio rápido actual:

  • Cadena de conexión del espacio de nombres de Event Hubs
  • Nombre del centro de eventos

Creación de un esquema

Siga las instrucciones que se indican en Creación de esquemas mediante el registro de esquema para crear un grupo de esquemas y un esquema.

  1. Cree un grupo de esquemas denominado contoso-sg mediante el portal del registro de esquema. Utilice el esquema JSON como tipo de serialización.

  2. En ese grupo de esquemas, cree un esquema de JSON con el nombre del esquema Microsoft.Azure.Data.SchemaRegistry.example.CustomerInvoice mediante el siguiente contenido de esquema.

    {
      "$id": "https://example.com/person.schema.json",
      "$schema": "https://json-schema.org/draft/2020-12/schema",
      "title": "CustomerInvoice",
      "type": "object",
      "properties": {
        "invoiceId": {
          "type": "string"
        },
        "merchantId": {
          "type": "string"
        },
        "transactionValueUsd": {
          "type": "integer"
        },
        "userId": {
          "type": "string"
        }
      }
    } 
    

Registro de una aplicación para acceder al registro de esquemas

Puede usar Microsoft Entra ID para autorizar a su aplicación de consumidor y productor de Kafka a acceder a los recursos de Azure Schema Registry. Para habilitarla, debe registrar la aplicación cliente con un inquilino de Microsoft Entra desde el Azure Portal.

Para registrar una aplicación de Microsoft Entra denominada example-app consulte Registro de la aplicación con un inquilino de Microsoft Entra.

  • tenant.id: establece el Id. de inquilino de la aplicación
  • client.id: establece el Id. de cliente de la aplicación
  • client.secret: establece el secreto del cliente para la autenticación

Y si usa identidad administrada, necesitaría:

  • use.managed.identity.credential: indica que se deben usar credenciales MSI, se deben usar para VM habilitadas para MSI
  • managed.identity.clientId: si se especifica, compila una credencial MSI con el Id. de cliente managed.identity.resourceId: si se especifica, compila la credencial MSI con el Id. de recurso especificado

Agregar usuario al rol Lector del registro de esquema

Agregue la cuenta de usuario al rol Lector del registro de esquema en el nivel de espacio de nombres. También puede usar el rol Colaborador del registro de esquema, pero no es necesario para este inicio rápido.

  1. En la página Espacio de nombres de Event Hubs, seleccione Control de acceso (IAM) en el menú de la izquierda.
  2. En la página Control de acceso (IAM), seleccione + Agregar ->Agregar asignación de roles en el menú.
  3. En la página Tipo de asignación, seleccione Siguiente.
  4. En la página Roles, seleccione Lector del registro de esquema y, después, seleccione Siguiente en la parte inferior de la página.
  5. Use el enlace + Seleccionar miembros para agregar la aplicación example-app que creó en el paso anterior a la función y después seleccione Siguiente.
  6. En la página Revisar + asignar, seleccione Revisar + asignar.

Actualización de la configuración de la aplicación cliente de las aplicaciones Kafka

Debe actualizar la configuración de cliente de las aplicaciones de productor y consumidor de Kafka con los detalles de la aplicación de Microsoft Entra y con la información del registro de esquema.

Para actualizar la configuración del productor de Kafka, vaya a azure-schema-registry-for-kafka/tree/master/java/json/samples/kafka-producer.

  1. Actualizar la configuración de la aplicación Kafka en src/main/resources/app.properties mediante la guía de Inicio rápido de Kafka para Event Hubs.

  2. Actualice los detalles de configuración para el productor en src/main/resources/app.properties utilizando la configuración relacionada con el registro de esquemas y la aplicación de Microsoft Entra que creó en el paso anterior como se indica a continuación:

    schema.group=contoso-sg
    schema.registry.url=https://<NAMESPACENAME>.servicebus.windows.net
    
     tenant.id=<>
     client.id=<>
     client.secret=<>
    
  3. Siga las mismas instrucciones y actualice también la configuración de azure-schema-registry-for-kafka/tree/master/java/json/samples/kafka-consumer.

  4. Tanto para las aplicaciones productoras como consumidoras de Kafka, se utiliza el siguiente esquema JSON:

    {
      "$id": "https://example.com/person.schema.json",
      "$schema": "https://json-schema.org/draft/2020-12/schema",
      "title": "CustomerInvoice",
      "type": "object",
      "properties": {
        "invoiceId": {
          "type": "string"
        },
        "merchantId": {
          "type": "string"
        },
        "transactionValueUsd": {
          "type": "integer"
        },
        "userId": {
          "type": "string"
        }
      }
    }
    

Uso del productor Kafka con validación de esquema JSON

Para ejecutar la aplicación Kafka producer, vaya a azure-schema-registry-for-kafka/tree/master/java/json/samples/kafka-producer.

  1. Puede ejecutar la aplicación productora para que produzca registros específicos del esquema JSON o registros genéricos. Para el modo de registros específicos es necesario generar primero las clases contra el esquema del productor mediante el siguiente comando de maven:

    mvn generate-sources
    
  2. A continuación, puede ejecutar la aplicación productora mediante los siguientes comandos.

    mvn clean package
    mvn -e clean compile exec:java -Dexec.mainClass="com.azure.schemaregistry.samples.producer.App"
    
  3. Después de ejecutar correctamente la aplicación productora, le pedirá que elija el esquema productor. Para este inicio rápido, puede elegir la opción 1 - producir SpecificRecords.

    Enter case number:
    1 - produce SpecificRecords
    
  4. Una vez que los datos se serialicen y publiquen correctamente, debería ver los siguientes registros de consola en su aplicación de producción:

    INFO com.azure.schemaregistry.samples.producer.KafkaJsonSpecificRecord - Sent Order Invoice 0
    INFO com.azure.schemaregistry.samples.producer.KafkaJsonSpecificRecord - Sent Order Invoice 1
    INFO com.azure.schemaregistry.samples.producer.KafkaJsonSpecificRecord - Sent Order Invoice 2
    

Uso del consumidor Kafka con validación de esquema JSON

Para ejecutar la aplicación consumidora Kafka, vaya a azure-schema-registry-for-kafka/tree/master/java/json/samples/kafka-consumer.

  1. Puede ejecutar la aplicación consumidora de modo que pueda consumir registros específicos del esquema JSON o registros genéricos. Para el modo de registros específicos es necesario generar primero las clases contra el esquema del productor mediante el siguiente comando de maven:

    mvn generate-sources
    
  2. A continuación, puede ejecutar la aplicación de consumo mediante el siguiente comando.

    mvn clean package
    mvn -e clean compile exec:java -Dexec.mainClass="com.azure.schemaregistry.samples.consumer.App"
    
  3. Después de ejecutar correctamente la aplicación consumidora, le pedirá que elija el esquema productor. Para este inicio rápido, puede elegir la opción 1 - consumir SpecificRecords.

    Enter case number:
    1 - consume SpecificRecords
    
  4. Una vez consumidos y deserializados los datos correctamente, debería ver los siguientes registros de consola en su aplicación de producción:

    INFO com.azure.schemaregistry.samples.consumer.KafkaJsonSpecificRecord - Invoice received: {invoiceId=Invoice 0, merchantId=Merchant Id 0, transactionValueUsd=0, userId=User Id 0}
    INFO com.azure.schemaregistry.samples.consumer.KafkaJsonSpecificRecord - Invoice received: {invoiceId=Invoice 1, merchantId=Merchant Id 1, transactionValueUsd=1, userId=User Id 1}
    INFO com.azure.schemaregistry.samples.consumer.KafkaJsonSpecificRecord - Invoice received: {invoiceId=Invoice 2, merchantId=Merchant Id 2, transactionValueUsd=2, userId=User Id 2}
    
    

Limpieza de recursos

Elimine el espacio de nombres de Event Hubs o elimine el grupo de recursos que contiene el espacio de nombres.