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 el formato de los mensajes. Pub/Sub aplica este formato. Los esquemas facilitan el consumo entre equipos de flujos de datos en tu organización mediante la creación de una autoridad central para los tipos de mensajes y los permisos. Un esquema de mensaje de Pub/Sub define los nombres y los tipos de datos de los campos de un mensaje.
Puedes crear un esquema y asociarlo con un tema para aplicar el esquema en los mensajes publicados. Si un mensaje específico no cumple con el esquema, no se publicará. También puedes crear revisiones adicionales de un esquema.
Tipos de esquemas
Puedes crear un esquema en Pub/Sub con uno de los siguientes marcos de trabajo:
Por ejemplo, el siguiente esquema define el inventario de un almacén, primero en el formato Avro y, luego, en el formato de 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 de búfer de protocolo
syntax = "proto3";
message ProtocolBuffer {
string product_name = 1;
int32 SKU = 2;
bool in_stock = 3;
}
Información importante sobre los esquemas
A continuación, se incluye información importante sobre la creación y administración de esquemas de Pub/Sub.
Para que un esquema funcione con Pub/Sub, debes definir solo un tipo de nivel superior. No se admiten las declaraciones de importación que hacen referencia a otros tipos.
Puedes asociar el mismo esquema a varios temas.
Puedes probar manualmente si un mensaje se valida en función de un esquema.
Cuotas y límites para esquemas
Los esquemas tienen los siguientes límites:
El campo de definición del esquema no puede superar los 300 KB de tamaño.
Un proyecto puede tener un máximo de 10,000 esquemas.
Un solo 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.