Programar snapshots do Filestore empresarial


Neste documento, mostramos como usar o Cloud Scheduler para programar e ajudar a proteger snapshots do Filestore.

Este documento é destinado a tomadores de decisão de TI, administradores de backup e administradores de recuperação de desastres (DR) que querem aprender ou criar snapshots programados do Filestore.

Objetivos

  • Configure o Cloud Functions e o arquivo de configuração JSON.
  • Criar um job do Cloud Scheduler.
  • Criar e rotular snapshots programados do Filestore.
  • Monitore o processo de criação de snapshots.

Custos

Neste documento, você usará os seguintes componentes faturáveis do Google Cloud:

Para gerar uma estimativa de custo baseada na projeção de uso deste tutorial, use a calculadora de preços. Novos usuários do Google Cloud podem estar qualificados para uma avaliação gratuita.

Depois de concluir este tutorial, exclua os recursos criados para evitar cobranças contínuas. Para mais informações, consulte Limpeza.

Antes de começar

  1. Faça login na sua conta do Google Cloud. Se você começou a usar o Google Cloud agora, crie uma conta para avaliar o desempenho de nossos produtos em situações reais. Clientes novos também recebem US$ 300 em créditos para executar, testar e implantar cargas de trabalho.
  2. No console do Google Cloud, na página do seletor de projetos, selecione ou crie um projeto do Google Cloud.

    Acessar o seletor de projetos

  3. Verifique se a cobrança está ativada para o seu projeto do Google Cloud.

  4. Ative as APIs Filestore, Cloud Scheduler, Cloud Functions, App Engine, and Cloud Build.

    Ative as APIs

  5. No console do Google Cloud, na página do seletor de projetos, selecione ou crie um projeto do Google Cloud.

    Acessar o seletor de projetos

  6. Verifique se a cobrança está ativada para o seu projeto do Google Cloud.

  7. Ative as APIs Filestore, Cloud Scheduler, Cloud Functions, App Engine, and Cloud Build.

    Ative as APIs

Modelo de implantação

O diagrama a seguir mostra o modelo de implantação compatível com o snapshot do Filestore do Cloud Functions.

Modelo de implantação com suporte para snapshots do Cloud Functions do Filestore.

O job do Cloud Scheduler coordena com o Cloud Functions para programar e gerar snapshots e arquivos de registro do Filestore. Os snapshots estão disponíveis no compartilhamento do Filestore.

Limitações conhecidas

Ao se preparar para configurar um programador de snapshots para instâncias do Filestore, considere as seguintes limitações:

  • A função exclui apenas um único snapshot quando necessário, mesmo que haja mais snapshots do programador do que o definido no arquivo de configuração da política de retenção ou se o arquivo de configuração da política de retenção for atualizado para manter menos snapshots do que antes.
  • Se você diminuir o valor numérico de snapshots no arquivo de configuração JSON, os snapshots redundantes da instância não serão excluídos automaticamente. Se você alterar a configuração, terá que excluir os snapshots redundantes manualmente.
  • Como o limite do ID do snapshot é de 75 caracteres, o nome da política de retenção tem um limite de 50 caracteres.

Prepare o ambiente

Nesta seção, você definirá suas variáveis de ambiente, clonará o repositório e criará os aplicativos e arquivos necessários para este tutorial.

Defina as variáveis de ambiente

  • No Cloud Shell, digite este comando:
gcloud components update
  • No Cloud Shell, crie as seguintes variáveis:

    export PROJECT_ID=PROJECT_ID
    export GCP_REGION=GCP_REGION
    export APP_ENGINE_REGION=APP_ENGINE_REGION
    export FUNCTION_NAME=FUNCTION_NAME
    export SCHEDULER_NAME=SCHEDULER_NAME
    export SCHEDULER_EXPRESSION="SCHEDULER_EXPRESSION"
    export SCHEDULER_TZ=SCHEDULER_TZ
    export SERVICE_ACCOUNT_NAME=SERVICE_ACCOUNT_NAME
    

    Substitua:

    • PROJECT_ID: o ID do projeto do Google Cloud em que você quer instalar a instância do Filestore Enterprise, a função do Cloud e o Cloud Scheduler.
    • GCP_REGION: a região do Google Cloud em que você quer instalar a instância do Filestore Enterprise, a função do Cloud e o Cloud Scheduler.
    • APP_ENGINE_REGION: uma região da lista de locais do App Engine em que você quer instalar o App Engine. Considere os seguintes requisitos:
      • Um projeto do Google Cloud pode ter apenas uma instância do App Engine, e a região do App Engine não pode ser alterada posteriormente.
      • O job do Cloud Scheduler e a instância do App Engine precisam residir na mesma região.
        • Por exemplo, se os recursos do Cloud Scheduler usarem us-central1, utilize o equivalente us-central do App Engine.
        • O App Engine aplica uma convenção de nomenclatura exclusiva para algumas regiões. Para mais detalhes, consulte a lista de locais do App Engine.
    • FUNCTION_NAME: o nome que você quer dar à função do Cloud.
    • SCHEDULER_NAME: o nome que você quer dar ao Cloud Scheduler.
    • SCHEDULER_EXPRESSION: a expressão cron do Cloud Scheduler, por exemplo, 10 0 * * *. Para mais informações, acesse Configurar programações de cron job.
    • SCHEDULER_TZ: o fuso horário do Cloud Scheduler, no formato de nome da lista de fusos horários do banco de dados tz, por exemplo, America/Los_Angeles.
    • SERVICE_ACCOUNT_NAME: o nome da conta de serviço recém-criada, por exemplo, scheduler-sa.

Crie uma conta de serviço

Nesta seção, você cria uma conta de serviço dedicada, que permite criar e gerenciar o job do função do Cloud e do Cloud Scheduler.

Quando você faz este procedimento, a conta de serviço requer as seguintes permissões:

  • file.instances.get
  • file.snapshots.list
  • file.snapshots.create
  • file.operations.get
  • file.snapshots.delete
  • cloudfunctions.functions.invoke

Para mais informações, consulte Permissões de IAM do Filestore ou Permissões de IAM do Cloud Functions.

Para criar a conta de serviço, faça o seguinte:

  1. No Cloud Shell, crie um papel dedicado para o programador de snapshots com as permissões necessárias:

    gcloud iam roles create snapshot_scheduler --project $PROJECT_ID --permissions file.instances.get,file.snapshots.list,file.snapshots.create,file.operations.get,file.snapshots.delete,logging.logEntries.create,cloudfunctions.functions.invoke --stage GA
    
  2. Crie a conta de serviço:

    gcloud iam service-accounts create $SERVICE_ACCOUNT_NAME --project $PROJECT_ID
    
  3. Vincule o papel à conta de serviço:

    gcloud projects add-iam-policy-binding $PROJECT_ID --member serviceAccount:$SERVICE_ACCOUNT_NAME@$PROJECT_ID.iam.gserviceaccount.com --role projects/$PROJECT_ID/roles/snapshot_scheduler
    

Criar uma instância do Filestore Enterprise

  1. Se você ainda não criou variáveis de ambiente para uma instância do Filestore que quer usar, crie as seguintes variáveis no Cloud Shell:

    export FILESTORE_INSTANCE_ID=FILESTORE_INSTANCE_ID
    export FILESTORE_SHARE_NAME=SHARE_NAME
    export FILESTORE_SHARE_SIZE=NUMERIC_IN_GB
    export NETWORK_NAME=VPC_NAME
    

    Substitua:

    • FILESTORE_INSTANCE_ID: o nome da instância do Filestore Enterprise
    • SHARE_NAME: o nome do compartilhamento da instância do Filestore empresarial
    • NUMERIC_IN_GB: o tamanho do compartilhamento da instância do Filestore Enterprise, um número entre 1024 e 10240, em incrementos de 256.
    • VPC_NAME: o nome da rede VPC em que você quer instalar a instância do Filestore empresarial
  2. Crie uma instância do Filestore, se ainda não tiver uma:

    gcloud filestore instances create $FILESTORE_INSTANCE_ID --network name=$NETWORK_NAME --file-share=capacity=$FILESTORE_SHARE_SIZE,name=$FILESTORE_SHARE_NAME --tier ENTERPRISE --project=$PROJECT_ID --location=$GCP_REGION
    

Para saber mais, consulte o artigo Criar instâncias.

Criar uma instância do App Engine

Nesta seção, você cria um App Engine para seu projeto do Google Cloud. Isso permite criar um job do Cloud Scheduler mais adiante neste tutorial.

Um projeto do Google Cloud pode ter apenas um App Engine, e a região não pode ser alterada posteriormente.

  • Se você ainda não tiver um, crie um no Cloud Shell:

    gcloud app create --region=$APP_ENGINE_REGION --project=$PROJECT_ID
    

Criar o arquivo de configuração JSON

Devido a uma limitação do Cloud Functions, o arquivo de configuração JSON pode ter até oito instâncias do Filestore. Se você tiver mais de oito instâncias do Filestore para programar snapshots, use outros jobs do Cloud Scheduler.

  • No Cloud Shell, crie um novo arquivo chamado request.json e edite o conteúdo de acordo com seu ambiente:

    {
                "retention_policy": "RETENTION_NAME",
                "instances": [
                    {"instance_path": "projects/PROJECT_ID/locations/GCP_REGION/instances/FILESTORE_INSTANCE_ID/",
                        "snapshots": NUMBER_OF_SNAPSHOTS
                    }
                ]
    }
    

    Substitua:

    • RETENTION_NAME: o nome do tipo de retenção de snapshot, que se torna parte do nome do snapshot. Por exemplo, daily.
    • NUMBER_OF_SNAPSHOTS: o número de snapshots.

Clonar o repositório

Clone o repositório do laboratório e insira o diretório:

  1. No Cloud Shell, clone o repositório do laboratório:

    git clone https://github.com/GoogleCloudPlatform/Filestore-Snapshot-Scheduler
    

    O resultado será assim:

    Cloning into Filestore-Snapshot-Scheduler
    
  2. Insira o diretório:

    cd Filestore-Snapshot-Scheduler
    

Criar a função do Cloud

No Cloud Shell, crie a solução da função do Cloud:

gcloud functions deploy $FUNCTION_NAME --region $GCP_REGION --runtime=python39 --trigger-http --source scheduler/ --timeout 540 --service-account $SERVICE_ACCOUNT_NAME@$PROJECT_ID.iam.gserviceaccount.com --entry-point main --project $PROJECT_ID

Exemplo:

gcloud functions deploy scheduler_func --region us-central1 --runtime=python39 --trigger-http --source scheduler/ --timeout 540 --service-account scheduler-sa@project1.iam.gserviceaccount.com --entry-point main --project project1

Criar um job do Cloud Scheduler

O job do Cloud Scheduler precisa estar em uma região equivalente à região do App Engine.

No Cloud Shell, crie um job do Cloud Scheduler com um ou mais programadores na mesma instância do Filestore:

gcloud scheduler jobs create http $SCHEDULER_NAME --schedule "$SCHEDULER_EXPRESSION" --uri "https://$GCP_REGION-$PROJECT_ID.cloudfunctions.net/$FUNCTION_NAME"  --http-method POST --message-body-from-file ../request.json --oidc-service-account-email $SERVICE_ACCOUNT_NAME@$PROJECT_ID.iam.gserviceaccount.com --time-zone $SCHEDULER_TZ --project $PROJECT_ID

No exemplo a seguir, o programador diário é executado às 20h:

gcloud scheduler jobs create http daily_scheduler --schedule "0 20 * * *" --uri "https://us-central1-project1.cloudfunctions.net/scheduler_func"  --http-method POST --message-body-from-file ../request.json --oidc-service-account-email scheduler-sa@project1.iam.gserviceaccount.com --time-zone America/Los_angeles --project project1

Validar os snapshots programados do Filestore

  1. No console do Google Cloud, acesse a página do Cloud Scheduler.

    Acessar o Cloud Scheduler

  2. Na linha do job que você criou, clique em Ações > Forçar a execução de um job.

  3. Clique em Atualizar.

    • Se o job for executado corretamente, a coluna Resultado da última execução vai mostrar um carimbo de data/hora do último job bem-sucedido.
    • Se o job falhar, faça o seguinte:

      1. Acesse a página Cloud Functions.

        Acessar o Cloud Functions

      2. Na linha da função que você criou, clique em Ações > Ver registros.

      3. Procure uma mensagem de erro e resolva o problema.

  4. No console do Google Cloud, acesse a página Instâncias do Filestore.

  5. Na lista Instâncias, selecione a instância e verifique se ela tem um snapshot com o formato de nome a seguir:

    sched-RETENTION_NAME-DATE-TIME
    

    Por exemplo, sched-daily-20220315-120640

Limpar

Para evitar cobranças na sua conta do Cloud Platform pelos recursos usados neste tutorial, exclua o projeto que os contém.

Exclua o projeto

  1. No Console do Google Cloud, acesse a página Gerenciar recursos.

    Acessar "Gerenciar recursos"

  2. Na lista de projetos, selecione o projeto que você quer excluir e clique em Excluir .
  3. Na caixa de diálogo, digite o ID do projeto e clique em Encerrar para excluí-lo.

A seguir