Este documento mostra-lhe como reverter um esquema para um tópico do Pub/Sub.
A operação de reversão permite-lhe criar outra revisão do esquema com a definição do esquema exata da revisão anterior especificada.
Antes de começar
- Compreenda como funcionam os esquemas do Pub/Sub.
- Crie um esquema.
Funções e autorizações necessárias
Para obter as autorizações de que
precisa para reverter esquemas e geri-los,
peça ao seu administrador que lhe conceda a função
Editor do Pub/Sub (roles/pubsub.editor
)
do IAM no seu projeto.
Para mais informações sobre a atribuição de funções, consulte o artigo Faça a gestão do acesso a projetos, pastas e organizações.
Esta função predefinida contém as autorizações necessárias para reverter esquemas e geri-los. Para ver as autorizações exatas que são necessárias, expanda a secção Autorizações necessárias:
Autorizações necessárias
São necessárias as seguintes autorizações para reverter esquemas e geri-los:
-
Crie um esquema:
pubsub.schemas.create
-
Anexe o esquema ao tópico:
pubsub.schemas.attach
-
Confirme uma revisão do esquema:
pubsub.schemas.commit
-
Elimine um esquema ou uma revisão de esquema:
pubsub.schemas.delete
-
Obtenha um esquema ou revisões de esquemas:
pubsub.schemas.get
-
Esquemas de listas:
pubsub.schemas.list
-
Revisões do esquema da lista:
pubsub.schemas.listRevisions
-
Reverter um esquema:
pubsub.schemas.rollback
-
Valide uma mensagem:
pubsub.schemas.validate
-
Obtenha a Política IAM para um esquema:
pubsub.schemas.getIamPolicy
-
Configure a Política IAM para um esquema:
pubsub.schemas.setIamPolicy
Também pode conseguir estas autorizações com funções personalizadas ou outras funções predefinidas.
Pode conceder funções e autorizações a responsáveis, como utilizadores, grupos, domínios ou contas de serviço. Pode criar um esquema num projeto e anexá-lo a um tópico localizado num projeto diferente. Certifique-se de que tem as autorizações necessárias para cada projeto.
Reverta uma revisão do esquema
Pode reverter um esquema através da Google Cloud consola, da CLI gcloud, da API Pub/Sub ou das bibliotecas cliente da nuvem. Siga estes passos:
Consola
Na Google Cloud consola, aceda à página Esquemas do Pub/Sub.
Clique no nome de um esquema existente.
É apresentada a página Detalhes do esquema do esquema.
Clique em Reverter.
É apresentada a caixa de diálogo Reverter esquema.
Selecione a revisão para a qual quer reverter o esquema.
Clique em Confirmar para guardar a operação de reversão.
É criada uma nova revisão com o esquema especificado na operação de reversão.
Na página Detalhes do esquema, selecione a versão mais recente do esquema e a versão que selecionou como origem para a operação de reversão.
Clique em Ver diferença.
Pode verificar se os dois esquemas são idênticos.
Pode usar a revisão do esquema que acabou de criar como a última revisão para validar um tópico atualizando o campo Última revisão permitida.
gcloud
gcloud pubsub schemas rollback SCHEMA_ID \ --revision-id=REVISION_ID
Onde:
- REVISION_ID é a revisão para a qual quer reverter.
REST
Para reverter um esquema, envie um pedido POST como o seguinte:
POST https://pubsub.googleapis.com/v1/projects/PROJECT_ID/schemas/SCHEMA_ID:rollback Authorization: Bearer $(gcloud auth application-default print-access-token) Content-Type: application/json --data @response-body.json
Especifique os seguintes campos no corpo do pedido:
{ "revisionId": REVISION_KD }
Onde:
- REVISION_KD é o ID da revisão para a qual reverter.
O corpo da resposta deve conter uma representação JSON de um recurso de esquema.
C++
Antes de experimentar este exemplo, siga as instruções de configuração do C++ no artigo Início rápido: usar bibliotecas de cliente. Para mais informações, consulte a documentação de referência da API C++ do Pub/Sub.
Ir
O exemplo seguinte usa a versão principal da biblioteca de cliente Go Pub/Sub (v2). Se ainda estiver a usar a biblioteca v1, consulte o guia de migração para a v2. Para ver uma lista de exemplos de código da v1, consulte os exemplos de código descontinuados.
Antes de experimentar este exemplo, siga as instruções de configuração do Go em Início rápido: usar bibliotecas de cliente. Para mais informações, consulte a documentação de referência da API Go do Pub/Sub.
Java
Antes de experimentar este exemplo, siga as instruções de configuração do Java no artigo Início rápido: usar bibliotecas cliente. Para mais informações, consulte a documentação de referência da API Java do Pub/Sub.
Python
Antes de experimentar este exemplo, siga as instruções de configuração do Python em Início rápido: usar bibliotecas cliente. Para mais informações, consulte a documentação de referência da API Python Pub/Sub.
Node.js
Antes de experimentar este exemplo, siga as instruções de configuração do Node.js em Início rápido: usar bibliotecas de cliente. Para mais informações, consulte a documentação de referência da API Node.js do Pub/Sub.
Node.js
Antes de experimentar este exemplo, siga as instruções de configuração do Node.js em Início rápido: usar bibliotecas de cliente. Para mais informações, consulte a documentação de referência da API Node.js do Pub/Sub.
O que se segue?
- Elimine uma revisão do esquema
- Elimine um esquema
- Esquemas de listas
- Liste as revisões de um esquema
- Subscreva um tópico com um esquema