Elige Pub/Sub o Pub/Sub Lite

El objetivo de este documento es ayudarte a elegir entre Pub/Sub y Pub/Sub Lite. Para este documento, se requiere que estés familiarizado con los conceptos básicos de Pub/Sub, como los temas y las suscripciones. Si eres nuevo en Pub/Sub, primero lee Qué es Pub/Sub.

Pub/Sub y Pub/Sub Lite son servicios de mensajería administrados y escalables de forma horizontal. Estos servicios admiten grandes volúmenes y requisitos de almacenamiento grandes. Pub/Sub suele ser la solución predeterminada para la mayoría de los casos prácticos de integración de aplicaciones y estadísticas. Cuenta con muchas funciones y está completamente administrado. Se recomienda Pub/Sub Lite para aplicaciones en las que la capacidad de procesamiento de mensajería es más estable, las cargas de trabajo pueden beneficiarse de un sistema basado en particiones y el costo es una preocupación importante.

Pub/Sub ofrece una gama más amplia de funciones, paralelismo por mensaje, enrutamiento global y capacidad de recursos con ajuste de escala automático. En términos de replicación de mensajes, Pub/Sub garantiza la replicación síncrona.

Pub/Sub Lite es una solución basada en particiones que intercambia la carga de trabajo operativa, la disponibilidad global y algunas funciones para mejorar la rentabilidad. Pub/Sub Lite requiere que reserves y administres de forma manual la capacidad de los recursos. En Pub/Sub Lite, puedes elegir temas Lite zonales o regionales. Los temas regionales de Lite ofrecen el mismo ANS de disponibilidad que los temas de Pub/Sub.

Ten en cuenta las diferencias de confiabilidad entre los dos servicios en cuanto a la replicación de mensajes. Pub/Sub admite la replicación de datos síncrona y usa tres zonas. Los temas regionales de Lite replican datos en una zona secundaria. Los temas de Zonal Lite replican datos en solo una zona.

Lista de tareas de requisitos del negocio

Las siguientes preguntas pueden ayudarte a elegir el servicio de mensajería de Pub/Sub correcto:

  • ¿La confiabilidad, el costo operativo mínimo y la facilidad de desarrollo son tus prioridades principales? Usar Pub/Sub

  • ¿Estás dispuesto a incurrir en alguna sobrecarga operativa adicional en términos de administración de la capacidad del tema, puedes trabajar con riesgos de disponibilidad inherentes a los servicios zonales y requieren un costo bajo? Usa temas Lite zonales.

  • ¿Necesitas cierta protección contra fallas zonales, estás dispuesto a incurrir en una sobrecarga operativa adicional en términos de administración de la capacidad del tema y requieres el costo por capacidad de procesamiento más bajo? Usar temas Lite regionales

Para obtener más información sobre las diferencias de costos entre Pub/Sub y Pub/Sub Lite, consulta la página de pricing.

Tabla de comparación de atributos

Atributo Pub/Sub Pub/Sub Lite
Transparencia de acceso No
Capacidad Aprovisionado automáticamente Aprovisiona antes de usar
Lenguajes de las bibliotecas cliente Java, Python, Go, Node.js, C++, C#, PHP, Ruby, SAP y ABAP Java, Python y Go
Suscripciones entre proyectos No
Claves de encriptación administradas por el cliente No
Temas de mensajes no entregados No
Entrega “exactamente una vez” No
Integraciones
Filtrado de mensajes Sí para los atributos del mensaje No
Replicación de mensajes No
Enruta mensajes Global Zonal o regional
Validación del esquema de mensajes No
Multizona en una sola región No Zona única o doble zona en una sola región
Entrega a domicilio Orden por clave Orden por partición
Seguimiento de confirmación de recepción de mensajes Por mensaje Cursor por partición
Precios Paga por lo que usa Paga por la capacidad que aprovisiones
Extremos de REST No
Espacio de nombres de recursos Global Zonal o regional
Período de retención Hasta 31 días Ilimitada
Extremos de Service Global y regional Regional
Almacenamiento Ilimitada Ilimitada
Suscripción

Replicación de datos

Los temas de Pub/Sub replican datos en tres zonas dentro de una región. Para obtener más información sobre la replicación de datos de Pub/Sub, consulta Replicación de datos en un tema.

Los temas regionales de Pub/Sub Lite replican datos en dos zonas dentro de una región. Los temas zonales de Pub/Sub Lite almacenan datos en una sola zona dentro de una región. Para obtener más información sobre la replicación de datos de Pub/Sub Lite, consulta Replicación de datos en un tema Lite.

Enruta mensajes

Tanto Pub/Sub como Pub/Sub Lite pueden publicar y suscribirse desde todas las regiones, y hasta fuera de Google Cloud.

Pub/Sub enruta los mensajes de forma global. Las aplicaciones alojadas en cualquier región pueden publicar mensajes en un solo tema. Los mensajes se procesan en la región más cercana permitida por las políticas de la organización y se reenvían a los suscriptores independientemente de la fuente.

Pub/Sub Lite enruta los mensajes dentro de una región o zona. Los suscriptores deben conectarse a la instancia del servicio en la región en la que se encuentra el tema. Como resultado, los publicadores y suscriptores deben mantener la conectividad de red a la misma región para la comunicación. Los publicadores pueden publicar datos en cualquier tema desde cualquier lugar, pero es posible que sea necesario conectarse a una región remota para agregar latencia de red. Los suscriptores que necesitan datos agregados publicados en temas en diferentes ubicaciones deben conectarse a cada instancia de servicio local relevante para leer los mensajes.

Espacio de nombres de recursos

Los temas y las suscripciones de Pub/Sub son recursos globales. El servicio de Pub/Sub puede almacenar mensajes en cualquier región que permita una política de almacenamiento de temas. Además, un tema y una suscripción a ese tema se pueden almacenar en proyectos diferentes, lo que permite una facturación y un control de acceso detallados. Por último, los suscriptores obtienen los mismos datos sin importar qué extremo de servicio usen para conectarse a Pub/Sub o qué extremo de servicio usó el publicador de los datos.

Los temas y las suscripciones de Zonal Lite son recursos zonales. Estos recursos deben estar en la misma zona y proyecto de Cloud.

Los temas y las suscripciones de Regional Lite son recursos regionales. Estos recursos deben estar en el mismo proyecto y la misma región de Cloud.

Para obtener una lista de las regiones y zonas compatibles con Pub/Sub Lite, consulta Ubicaciones de Pub/Sub Lite.

Administración de capacidad

Pub/Sub escala automáticamente. La capacidad para la publicación de mensajes se aprovisiona de forma automática, de modo que puedas enviar y recibir mensajes en cualquier frecuencia, hasta las cuotas que configures para tu proyecto.

Pub/Sub Lite se aprovisiona de forma manual. Debes configurar la cantidad de particiones por tema de Lite. También debes aprovisionar la capacidad de procesamiento y almacenamiento. La capacidad de procesamiento se puede aprovisionar con reservas de Lite.

Modos de entrega

Pub/Sub admite varios modos de entrega de mensajes. Estos incluyen Pull (sondeo tradicional), Push (HTTPS POST), StreamingPull (RPC bidireccional, para la latencia más baja y la mayor eficiencia) y extracción de HTTP REST y gRPC.

Pub/Sub Lite solo admite la transmisión de la entrega de mensajes de extracción de gRPC. Para solicitar mensajes, los suscriptores establecen conexiones de transmisión bidireccional con cada partición.

Paralelismo

Pub/Sub usa el paralelismo por mensaje. Esto permite el procesamiento simultáneo de cualquier cantidad de mensajes, desde uno o miles de clientes para una sola suscripción.

Pub/Sub Lite usa el paralelismo basado en particiones. Esto obliga a un cliente a procesar cada partición de datos en orden lineal en una sola instancia de cliente. Esto limita la cantidad máxima de instancias de cliente a la cantidad máxima de particiones.

Canalizaciones de transmisión

Pub/Sub y Pub/Sub Lite están integrados en Dataflow para el procesamiento de transmisión y la integración de datos sin servidores. Pub/Sub permite que Dataflow realice un escalamiento más flexible y admite Dataflow SQL.

Para comenzar con Dataflow y Pub/Sub o Pub/Sub Lite, prueba estos instructivos: