No Pub/Sub, um tópico é um recurso nomeado que representa um feed de mensagens. É necessário criar um tópico para poder publicar ou assinar. O Pub/Sub é compatível com dois tipos de tópicos: um padrão e um de importação.
Este documento descreve como criar um tópico padrão do Pub/Sub. Para saber mais sobre um tópico de importação e como criar um, consulte Sobre tópicos de importação.
Para criar um tópico, use o console Trusted Cloud , a Google Cloud CLI, a biblioteca de cliente ou a API Pub/Sub.
Antes de começar
Saiba mais sobre o serviço do Pub/Sub e a terminologia dele.
Saiba mais sobre o processo de publicação.
Papéis e permissões necessárias
Para receber as permissões necessárias para criar um tópico,
peça ao administrador para conceder a você o
papel do IAM de editor do Pub/Sub(roles/pubsub.editor
)
no seu projeto.
Para mais informações sobre a concessão de papéis, consulte Gerenciar o acesso a projetos, pastas e organizações.
Esse papel predefinido contém as permissões necessárias para criar um tópico. Para conferir as permissões exatas necessárias, expanda a seção Permissões necessárias:
Permissões necessárias
As seguintes permissões são necessárias para criar um tópico:
-
Conceda esta permissão para criar um tópico no projeto:
pubsub.topics.create
Essas permissões também podem ser concedidas com funções personalizadas ou outros papéis predefinidos.
É possível configurar o controle de acesso no nível do projeto e no nível do recurso individual. É possível criar uma assinatura em um projeto e anexá-la a um tópico localizado em um projeto diferente. Verifique se você tem as permissões necessárias para cada projeto.
Propriedades de um tema
Ao criar ou atualizar um tópico, você precisa especificar as propriedades dele.
Adicione uma assinatura padrão
Adiciona uma assinatura padrão ao tópico do Pub/Sub. Você pode criar outra assinatura para o tópico depois que ele for criado. A assinatura padrão tem as seguintes propriedades:
- ID da assinatura de
-sub
- Tipo de entrega pull
- Duração da retenção de mensagens de sete dias
- Expiração após 31 dias de inatividade
- Prazo de confirmação de recebimento de 10 segundos
- Política de repetição imediata
Ativar ingestão
Ao ativar essa propriedade, você pode ingerir dados de streaming de fontes externas em um tópico para usar os recursos do Trusted Cloud. Para criar um tópico de importação para ingestão, consulte o seguinte:
Ativar retenção de mensagens
Especifica por quanto tempo o tópico do Pub/Sub retém as mensagens após a publicação. Após o período de retenção de mensagens, o Pub/Sub pode descartar a mensagem, independentemente do estado de confirmação. As tarifas de armazenamento de mensagens são cobradas pelo armazenamento de todas as mensagens publicadas no tópico.
- Padrão = não ativado
- Valor mínimo = 10 minutos
- Valor máximo = 31 dias
Exportar dados de mensagem para o BigQuery
Ao ativar essa propriedade, é possível criar uma assinatura do BigQuery que grava mensagens em uma tabela do BigQuery conforme elas são recebidas. Não é necessário configurar um cliente assinante separado. Para mais informações sobre as assinaturas do BigQuery, consulte Assinaturas do BigQuery.
Fazer backup de dados de mensagens no Cloud Storage
Ao ativar essa propriedade, é possível criar uma assinatura do Cloud Storage que grava mensagens em uma tabela do Cloud Storage à medida que elas são recebidas. Não é necessário configurar um cliente assinante separado. Para mais informações sobre as assinaturas do Cloud Storage, consulte Assinaturas do Cloud Storage.
Transformações
As SMTs de tópico permitem modificações leves nos dados e atributos das mensagens diretamente no Pub/Sub. Esse recurso permite a limpeza, filtragem ou conversão de formato de dados antes que as mensagens sejam publicadas no tópico.
Para mais informações sobre SMTs, consulte a visão geral das SMTs.
Google Cloud-powered encryption key
Especifica que o tópico está criptografado usando Google Cloud-powered encryption keys. O Pub/Sub criptografa mensagens com Google Cloud-powered encryption keys por padrão. Portanto, escolher essa opção mantém o comportamento padrão. O Google lida com o gerenciamento e a rotação de chaves automaticamente, garantindo que suas mensagens estejam sempre protegidas com a criptografia mais forte disponível. Essa opção não exige mais configurações. Para mais informações sobre Google Cloud-powered encryption keys, consulte Criptografia padrão com Google Cloud-powered encryption keys.
Chave do Cloud KMS
Especifica se o tópico é criptografado com uma chave de criptografia gerenciada pelo cliente (CMEK). O Pub/Sub criptografa mensagens com Google Cloud-powered encryption keys por padrão. Se você especificar essa opção, o Pub/Sub usará o padrão de criptografia de envelope com CMEK. Nessa abordagem, o Cloud KMS não criptografa as mensagens. Em vez disso, o Cloud KMS criptografa as chaves de criptografia de dados (DEKs) que o Pub/Sub cria para cada tópico. O Pub/Sub criptografa as mensagens usando a DEK mais recente gerada para o tópico. O Pub/Sub descriptografa as mensagens pouco antes de elas serem entregues aos assinantes. Para mais informações sobre como criar uma chave, consulte Configurar a criptografia de mensagens.
Criar um tópico
Crie um tópico antes de publicar ou assinar.
Console
Para criar um tópico, siga estas etapas:
No console Trusted Cloud , acesse a página Criar tópico do Pub/Sub.
No campo ID do tópico, insira um ID para o tópico. Para mais informações sobre como nomear tópicos, consulte as diretrizes de nomenclatura.
Mantenha a opção Adicionar uma assinatura padrão.
Opcional. Não selecione as outras opções.
Clique em Criar tópico.
gcloud
Para criar um tópico, execute o comando gcloud pubsub
topics create
:
gcloud pubsub topics create TOPIC_ID
REST
Para criar um tópico, use o método
projects.topics.create
:
A solicitação precisa ser autenticada com um token de acesso no cabeçalho Authorization
. Para conseguir um token de acesso para o Application Default Credentials: gcloud auth application-default print-access-token
.
PUT https://pubsub.googleapis.com/v1/projects/PROJECT_ID/topics/TOPIC_ID Authorization: Bearer ACCESS_TOKEN
Em que:
- PROJECT_ID é o ID do projeto;
- TOPIC_ID é o ID do tópico.
Resposta:
{ "name": "projects/PROJECT_ID/topics/TOPIC_ID" }
C++
Antes de tentar esse exemplo, siga as instruções de configuração do C++ em Guia de início rápido: como usar bibliotecas de cliente. Para mais informações, consulte a documentação de referência da API Pub/Sub C++.
C#
Antes de tentar esse exemplo, siga as instruções de configuração do C# em Guia de início rápido: como usar bibliotecas de cliente. Para mais informações, consulte a documentação de referência da API Pub/Sub C#.
Go
O exemplo a seguir usa a versão principal da biblioteca de cliente do Go Pub/Sub (v2). Se você ainda estiver usando a biblioteca v1, consulte o guia de migração para a v2. Para conferir uma lista de exemplos de código da v1, consulte os exemplos de código descontinuados.
Antes de tentar esse exemplo, siga as instruções de configuração do Go em Guia de início rápido: como usar bibliotecas de cliente. Para mais informações, consulte a documentação de referência da API Pub/Sub Go.
Java
Antes de tentar essa amostra, siga as instruções de configuração do Java em Guia de início rápido: como usar bibliotecas de cliente. Para mais informações, consulte a documentação de referência da API Pub/Sub Java.
Node.js
Antes de tentar essa amostra, siga as instruções de configuração do Node.js em Guia de início rápido: como usar bibliotecas de cliente. Para mais informações, consulte a documentação de referência da API Pub/Sub Node.js.
Node.ts
Antes de tentar essa amostra, siga as instruções de configuração do Node.js em Guia de início rápido: como usar bibliotecas de cliente. Para mais informações, consulte a documentação de referência da API Pub/Sub Node.js.
PHP
Antes de tentar esse exemplo, siga as instruções de configuração do PHP em Guia de início rápido: como usar bibliotecas de cliente. Para mais informações, consulte a documentação de referência da API Pub/Sub PHP.
Python
Antes de tentar esse exemplo, siga as instruções de configuração do Python em Guia de início rápido: como usar bibliotecas de cliente. Para mais informações, consulte a documentação de referência da API Pub/Sub Python.
Ruby
O exemplo a seguir usa a biblioteca de cliente do Ruby Pub/Sub v3. Se você ainda estiver usando a biblioteca v2, consulte o guia de migração para a v3. Para conferir uma lista de exemplos de código do Ruby v2, consulte os exemplos de código descontinuados.
Antes de tentar esse exemplo, siga as instruções de configuração do Ruby em Guia de início rápido: como usar bibliotecas de cliente. Para mais informações, consulte a documentação de referência da API Pub/Sub Ruby.
A seguir
Escolha o tipo de assinatura para seu tópico.
Saiba como publicar uma mensagem em um tópico.
Resolver um problema com um tema.
Crie ou modifique um tópico com a CLI gcloud, as APIs REST ou as bibliotecas de cliente.