Descripción general del esquema

Un esquema de Pub/Sub es una función opcional que puedes usar para aplicar el formato del campo data en un mensaje de Pub/Sub.

Un esquema crea un contrato entre el publicador y el suscriptor sobre la formato de los mensajes. Pub/Sub aplica este formato de manera forzosa. Los esquemas facilitan el consumo de flujos de datos entre equipos en tu organización mediante la creación de una autoridad central para los tipos de mensajes y permisos. Un esquema de mensajes de Pub/Sub define los nombres y tipos de datos para los campos de un mensaje.

Puedes crear un esquema y asociarlo con un tema para aplicar el esquema para los mensajes publicados. Si un mensaje específico no no cumplen con el esquema, el mensaje no se publica. También puedes crear o revisiones adicionales de un esquema.

Tipos de esquemas

Puedes crear un esquema en Pub/Sub con uno de los los siguientes frameworks:

Después de crear un esquema, puedes realizar varias operaciones un esquema o una revisión de esquema. Por ejemplo, puedes borrar un esquema o borrar una revisión del esquema.

Por ejemplo, el siguiente esquema define el inventario de un almacén, en formato Avro y luego en búfer de protocolo.

Formato Apache Avro

{
 "type" : "record",
 "name" : "Avro",
 "fields" : [
   {
     "name" : "ProductName",
     "type" : "string",
     "default": ""
   },
   {
     "name" : "SKU",
     "type" : "int",
     "default": 0
   },
   {
     "name" : "InStock",
     "type" : "boolean",
     "default": false
   }
 ]
}

Formato del búfer de protocolo

syntax = "proto3";
message ProtocolBuffer {
  string product_name = 1;
  int32 SKU = 2;
  bool in_stock = 3;
}

Cuotas y límites para esquemas

Los esquemas tienen los siguientes límites:

  • El campo de definición de esquema no puede superar los 50 KB de tamaño.

  • Un proyecto puede tener un máximo de 10,000 esquemas.

  • Un mismo esquema no puede tener más de 20 revisiones.

    Para obtener información sobre los esquemas y límites relacionados con Pub/Sub, consulta Cuotas y límites de Pub/Sub.

¿Qué sigue?