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. Es rico en 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 cuanto a la 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 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 admite la replicación síncrona de datos y usa tres zonas. Los temas Lite regionales replican los datos en una 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:
¿La confiabilidad, el costo operativo mínimo y la facilidad de desarrollo son tus prioridades? Usa Pub/Sub.
¿Estás dispuesto a incurrir en una sobrecarga operativa adicional en términos de administración de la capacidad del tema, puedes trabajar con los riesgos de disponibilidad inherentes a los servicios zonales y necesitas un costo bajo? Usa temas Lite zonales.
¿Necesitas protección contra fallas zonales, estás dispuesto a incurrir en una sobrecarga operativa adicional en términos de administración de la capacidad de temas y necesitas el costo más bajo por rendimiento? 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 | Una sola zona o zona doble en una sola región |
Pedido a domicilio | Ordenamiento por clave | Orden por partición |
Seguimiento de confirmació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 de Pub/Sub Lite zonales 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, incluso 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 se reenvían a los suscriptores sin importar 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 la conectividad de red en 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 Lite zonales 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 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. Entre estas se incluyen Pull (sondeo tradicional), Push (HTTPS POST), StreamingPull (RPC bidireccional, para la latencia más baja y la mayor eficiencia) y la extracción de REST y gRPC HTTP.
Pub/Sub Lite solo admite la entrega de mensajes de extracción de gRPC de transmisión. 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: