Este documento explica como desativar automaticamente o faturamento em um projeto quando os custos atingirem ou excederem o orçamento do projeto. Ao desativar o faturamento em um projeto, você encerra todos os serviços Google Cloud no projeto, incluindo os serviços do nível gratuito. Para uma resposta mais sutil às notificações de orçamento, consulte Controlar o uso de recursos com notificações.
Talvez você limite os custos porque tem um valor máximo de dinheiro que pode gastar no Google Cloud. Nesses casos, quando o limite de orçamento é atingido, convém encerrar todos os serviços Google Cloud e o uso para interromper a geração de custos. Desativar o faturamento no seu projeto é um método eficiente para evitar custos nesse projeto.
Limitações
Há um atraso entre a geração de custos e o recebimento das notificações de orçamento. Por isso, é possível que haja custos extras pelo uso que não foi faturado no momento em que todos os serviços foram interrompidos. Seguir as etapas neste exemplo não garante que você não vai gastar mais do que o orçamento. Se você tiver uma quantidade limitada de fundos, defina o orçamento máximo abaixo dos recursos disponíveis para compensar atrasos no faturamento.
Não é possível desativar o faturamento em um projeto bloqueado para uma conta de faturamento. Para saber mais sobre como bloquear e desbloquear projetos, consulte Proteger o link entre um projeto e a conta de faturamento dele.
Antes de começar
Antes de começar, faça o seguinte:
- Ativar a API Cloud Billing
- Criar um orçamento com escopo para um único projeto
- Configurar notificações de orçamento programático
Configurar uma função do Cloud Run
Para desativar o Cloud Billing em um projeto, crie uma função do Cloud Run e configure-a para chamar a API Cloud Billing.
- Siga as etapas em Criar uma função do Cloud Run. Verifique se o tipo de gatilho está definido como o mesmo tópico do Pub/Sub que o orçamento vai usar.
Adicione as seguintes dependências:
Node.js
Copie o seguinte para o arquivo
package.json
:Python
Copie o seguinte para o arquivo
requirements.txt
:Copie o código abaixo na função do Cloud Run:
Node.js
Python
Defina o Ponto de entrada como a função correta a ser executada:
Node.js
Defina o Ponto de entrada como
stopBilling
.Python
Defina o Ponto de entrada como
stop_billing
.Revise a lista de variáveis de ambiente definidas automaticamente para determinar se você precisa definir manualmente a variável GOOGLE_CLOUD_PROJECT para o projeto em que quer desativar o Cloud Billing.
Clique em IMPLANTAR.
Configurar permissões da conta de serviço
Sua função do Cloud Run é executada como uma conta de serviço criada automaticamente. Para desativar o faturamento, é necessário conceder à conta de serviço permissões para todos os serviços do projeto que ela precisa modificar. Para isso, siga estas etapas:
- Identifique a conta de serviço correta conferindo os detalhes da sua função do Cloud Run. A conta de serviço está listada na parte de baixo da página.
Acesse a página IAM no console do Google Cloud para definir as permissões apropriadas.
Para modificar as permissões da conta de faturamento, acesse a página Gerenciamento da conta no console do Google Cloud, adicione a conta de serviço como um princípio na conta do Cloud Billing e defina as permissões apropriadas da conta de faturamento.
Saiba como configurar permissões para contas do Cloud Billing.
Testar se o Faturamento do Google Cloud está desativado
Quando o orçamento envia uma notificação, o projeto especificado não tem mais uma conta do Cloud Billing associada a ele. Para garantir que a função funcione conforme o esperado, siga as etapas em Testar uma função do Cloud Run.
Se for bem-sucedido, o projeto não vai mais aparecer na conta do Cloud Billing e os recursos no projeto serão desativados, incluindo a função do Cloud Run, se ela estiver no mesmo projeto.
Para continuar usando os recursos Google Cloud no projeto, no console do Google Cloud, reaative manualmente o Cloud Billing para seu projeto.
A seguir
Confira outros exemplos de notificações programáticas para saber como fazer o seguinte: