El objetivo de este documento es ayudarte a elegir entre Pub/Sub y Pub/Sub Lite. Para leer este documento, debes conocer los conceptos básicos de Pub/Sub, como los temas y las suscripciones. Si eres nuevo en Pub/Sub, lee primero ¿Qué es Pub/Sub?.
Pub/Sub y Pub/Sub Lite son servicios de mensajería administrados y escalables de forma horizontal. Estos servicios pueden manejar un gran volumen y admiten grandes requisitos de almacenamiento. Por lo general, Pub/Sub es la solución predeterminada para la mayoría de los casos de uso de integración y análisis de aplicaciones. Cuenta con muchas funciones y está completamente administrado. Se recomienda Pub/Sub Lite para aplicaciones en las que el rendimiento de la 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 variedad más amplia de funciones, paralelismo por mensaje, enrutamiento global y ajuste de escala automático de la capacidad de los recursos. En condiciones de la replicación de mensajes, Pub/Sub garantiza para 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 por la eficiencia en costos. Pub/Sub Lite requiere que reserves y administres la capacidad de recursos de forma manual. En Pub/Sub Lite, puedes elegir temas Lite regionales o zonales. Los temas Lite regionales ofrecen el mismo ANS de disponibilidad que los temas de Pub/Sub.
Ten en cuenta las diferencias de confiabilidad entre los dos servicios en términos de replicación de mensajes. Pub/Sub es compatible con la arquitectura y usa tres zonas. Los temas regionales de Lite replican datos en un zona secundaria. Los temas Lite zonales replican los datos en una sola zona.
Lista de tareas de los requisitos empresariales
Las siguientes preguntas pueden ayudarte a elegir el servicio de mensajería de Pub/Sub correcto:
Son confiabilidad, costo operativo mínimo y facilidad de desarrollo. cuáles son tus prioridades principales? Usar Pub/Sub
¿Está dispuesto a incurrir en alguna sobrecarga operativa adicional en términos de administrar la capacidad de los temas, puede trabajar con la disponibilidad inherentes a los servicios zonales y requieren un costo bajo? Usa temas Lite zonales.
¿Necesitas protección contra fallas zonales?, están dispuestos a incurrir en una sobrecarga operativa adicional en términos de administrar la capacidad de los temas y requieren la menor de procesamiento? Usa temas regionales de Lite.
Para obtener más información sobre las diferencias de costos entre Pub/Sub y Pub/Sub Lite, consulta la página de precios.
Tabla de comparación de funciones
Atributo | Pub/Sub | Pub/Sub Lite |
---|---|---|
Transparencia de acceso | Sí | 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 | Sí | No |
Claves de encriptación administradas por el cliente | Sí | No |
Temas de mensajes no entregados | Sí | No |
Entrega “exactamente una vez” | Sí | No |
Integraciones | ||
Filtrado de mensajes | Sí para los atributos del mensaje | No |
Replicación de mensajes | Sí | No |
Enruta mensajes | Global | Zonal o regional |
Validación del esquema de mensajes | Sí | No |
Multizona en una sola región | No | Zona única o doble zona en una sola región |
Pedido 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 usas | Paga por la capacidad que aprovisiones |
Extremos de REST | Sí | No |
Espacio de nombres de recursos | Global | Zonal o regional |
Período de retención | Hasta 31 días | Ilimitado |
Extremos de Service | Global y regional | Regional |
Almacenamiento | Ilimitado | Ilimitado |
Suscripción |
Replicación de datos
Los temas de Pub/Sub replican los datos en tres zonas 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 los datos en dos zonas dentro de una región. Los temas zonales de Pub/Sub Lite almacenan datos una sola zona dentro de una región. Para obtener más información sobre 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 se suscriban 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 tu organización y no se reenvían a los suscriptores independientemente de la fuente.
Pub/Sub Lite enruta los mensajes dentro de una región o una 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 conectividad a la misma región para la comunicación. Los publicadores pueden publicar datos en cualquier tema desde cualquier lugar, pero esto puede requerir que se conecten a una región remota, lo que agrega 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 permitida por 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 el extremo de servicio que 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 el mismo proyecto y zona de Cloud.
Los temas y las suscripciones Lite regionales 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 que admite 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 (sondeos tradicionales), Envío (HTTPS POST), StreamingPull (RPC bidireccional para los latencia y la mayor eficiencia), y extraer HTTP REST y gRPC.
Pub/Sub Lite solo admite la transmisión de mensajes de extracción de gRPC y la entrega de modelos de AA. Para solicitar mensajes, los suscriptores establecen transmisiones bidireccionales conexiones de red 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: