Escolher o Pub/Sub ou o Pub/Sub Lite

Este documento foi criado para ajudar você a escolher entre o Pub/Sub e o Pub/Sub Lite. Para seguir este documento, é necessário ter familiaridade com os conceitos básicos do Pub/Sub, como tópicos e assinaturas. Se você não tem experiência com o Pub/Sub, leia O que é o Pub/Sub primeiro.

O Pub/Sub e o Pub/Sub Lite são serviços de mensagens gerenciados e escalonáveis horizontalmente. Esses serviços podem processar grandes volumes e atender a requisitos de armazenamento grandes. O Pub/Sub geralmente é a solução padrão para a maioria dos casos de uso de integração e análise de aplicativos. Ele é totalmente gerenciado e tem muitos recursos. O Pub/Sub Lite é recomendado para aplicativos em que a capacidade de processamento de mensagens é mais estável, as cargas de trabalho podem se beneficiar de um sistema baseado em partições e o custo é uma preocupação significativa.

O Pub/Sub oferece uma variedade maior de recursos, paralelismo por mensagem, roteamento global e escalonamento automático da capacidade dos recursos. Em termos de replicação de mensagens, o Pub/Sub garante a replicação síncrona.

O Pub/Sub Lite é uma solução baseada em partições que troca carga de trabalho operacional, disponibilidade global e alguns recursos por eficiência de custo. O Pub/Sub Lite exige que você reserve e gerencie manualmente a capacidade dos recursos. No Pub/Sub Lite, você pode escolher tópicos zonais ou regionais do Lite. Os tópicos regionais do Lite oferecem o mesmo SLA de disponibilidade dos tópicos do Pub/Sub.

Observe as diferenças de confiabilidade entre os dois serviços em termos de replicação de mensagens. O Pub/Sub oferece suporte à replicação síncrona de dados e usa três zonas. Os tópicos regionais do Lite replicam dados para uma zona secundária. Os tópicos do Lite zonais replicam dados em apenas uma zona.

Lista de verificação de requisitos comerciais

As perguntas a seguir podem ajudar você a escolher o serviço de mensagens do Pub/Sub certo:

  • Confiabilidade, custo operacional mínimo e facilidade de desenvolvimento são suas principais prioridades? Use o Pub/Sub.

  • Você está disposto a arcar com alguma sobrecarga operacional adicional em termos de gerenciamento da capacidade de tópicos, pode trabalhar com riscos de disponibilidade inerentes aos serviços zonais e precisa de baixo custo? Usar tópicos do Lite zonais.

  • Você precisa de proteção contra falhas zonais, está disposto a incorrer em uma sobrecarga operacional adicional em termos de gerenciamento da capacidade de tópicos e exige o menor custo por taxa de transferência? Usar tópicos regionais do Lite.

Para saber mais sobre as diferenças de custo entre o Pub/Sub e o Pub/Sub Lite, consulte a página de preços.

Tabela de comparação de recursos

Recurso Pub/Sub Pub/Sub Lite
Transparência no acesso Sim Não
Capacidade Aprovisionado automaticamente Provisionar antes de usar
Linguagens de biblioteca de cliente Java, Python, Go, Node.js, C++, C#, PHP, Ruby, SAP e ABAP Java, Python, Go
Assinaturas entre projetos Sim Não
Chaves de criptografia gerenciadas pelo cliente Sim Não
Tópicos de mensagens inativas Sim Não
Entrega única Sim Não
Integrações
Filtragem de mensagens Sim para atributos de mensagem Não
Replicação de mensagens Sim Não
Roteamento de mensagens Global Zonal ou regional
Validação do esquema de mensagem Sim Não
Várias zonas em uma única região Não Zona única ou dupla em uma única região
Entrega solicitada Ordenação por chave Ordenação por partição
Acompanhamento de confirmação de mensagens Por mensagem Cursor por partição
Preços Pague pelo que usar Pague pela capacidade que você provisiona
Endpoints REST Sim Não
Namespace de recursos Global Zonal ou regional
Período de armazenamento Até 31 dias Ilimitado
Endpoints de Serviço Global e regional Regional
Armazenamento Ilimitado Ilimitado
Assinatura

Replicação de dados

Os tópicos do Pub/Sub replicam dados em três zonas dentro de uma região. Para mais informações sobre a replicação de dados do Pub/Sub, consulte Replicação de dados em um tópico.

Os tópicos regionais do Pub/Sub Lite replicam dados para duas zonas em uma região. Os tópicos zonais do Pub/Sub Lite armazenam dados em uma única zona dentro de uma região. Para mais informações sobre a replicação de dados do Pub/Sub Lite, consulte Replicação de dados em um tópico Lite.

Roteamento de mensagens

O Pub/Sub e o Pub/Sub Lite podem publicar e fazer assinaturas de todas as regiões, até mesmo fora do Google Cloud.

O Pub/Sub roteia mensagens globalmente. Aplicativos hospedados em qualquer região podem publicar mensagens em um único tópico. As mensagens são processadas na região mais próxima permitida pelas políticas da organização e encaminhadas aos assinantes independentemente da origem.

O Pub/Sub Lite encaminha mensagens em uma região ou zona. Os assinantes precisam se conectar à instância do serviço na região em que o tópico está localizado. Como resultado, os editores e assinantes precisam manter a conectividade de rede na mesma região de comunicação. Os editores podem publicar dados em qualquer tópico de qualquer lugar, mas isso pode exigir conexão a uma região remota, adicionando latência de rede. Os assinantes que precisam de dados agregados publicados em tópicos em diferentes locais precisam se conectar a todas as instâncias de serviço locais relevantes para ler as mensagens.

Namespace de recursos

Os tópicos e as assinaturas do Pub/Sub são recursos globais. O serviço Pub/Sub pode armazenar mensagens em qualquer região permitida por uma política de armazenamento de tópicos. Além disso, um tópico e uma assinatura desse tópico podem ser armazenados em projetos diferentes, permitindo controle de acesso e faturamento detalhado. Por fim, os assinantes recebem os mesmos dados, independentemente do endpoint de serviço usado para se conectar ao Pub/Sub ou de qual endpoint de serviço foi usado pelo editor dos dados.

Os tópicos e as assinaturas do Lite por zona são recursos zonais. Esses recursos precisam estar no mesmo projeto na nuvem e zona.

Os tópicos e as assinaturas do Lite regionais são recursos regionais. Esses recursos precisam estar no mesmo projeto na nuvem e região.

Para ver uma lista de regiões e zonas compatíveis com o Pub/Sub Lite, consulte Locais do Pub/Sub Lite.

Gerenciamento de capacidade

O Pub/Sub é escalonado automaticamente. A capacidade de publicação de mensagens é provisionada automaticamente, de modo que você possa enviar e receber mensagens a qualquer taxa, até as cotas configuradas para o projeto.

O Pub/Sub Lite é provisionado manualmente. É preciso configurar o número de partições por tópico do Lite. Também é preciso provisionar capacidade de armazenamento e capacidade. A capacidade é provisionada com reservas do Lite.

Modos de transferência

O Pub/Sub é compatível com vários modos de entrega de mensagens. Entre eles estão Pull (sondagem tradicional), Push (HTTPS POST), StreamingPull (RPC bidirecional, para menor latência e maior eficiência) e pull de REST e gRPC HTTP.

O Pub/Sub Lite só é compatível com a entrega de mensagens pull de gRPC de streaming. Para solicitar mensagens, os assinantes estabelecem conexões de streaming bidirecionais com cada partição.

Paralelismo

O Pub/Sub usa o paralelismo por mensagem. Isso permite o processamento simultâneo de qualquer número de mensagens, de um ou milhares de clientes, para uma única assinatura.

O Pub/Sub Lite usa paralelismo baseado em partição. Isso força um cliente a processar cada partição de dados em ordem linear em uma única instância do cliente. Isso limita o número máximo de instâncias de cliente a no máximo o número de partições.

Pipelines de streaming

Tanto o Pub/Sub quanto o Pub/Sub Lite são integrados ao Dataflow para processamento de stream e integração de dados sem servidor. O Pub/Sub permite que o Dataflow seja escalonado de maneira mais flexível e compatível com o Dataflow SQL.

Para começar a usar o Dataflow e o Pub/Sub ou o Pub/Sub Lite, confira estes tutoriais: