Conectar a partir do Cloud Run

Neste guia de início rápido, você vai aprender a implantar um aplicativo de amostra em um serviço do Cloud Run usando o console Google Cloud e um aplicativo cliente. Este aplicativo de exemplo conecta o Cloud Run ao AlloyDB para PostgreSQL.

Exemplo de código de aplicativo

O código do aplicativo de amostra para este guia de início rápido está localizado no diretório examples/go do repositório GoogleCloudPlatform/alloydb-auth-proxy do GitHub.

O aplicativo é escrito na linguagem de programação Go e serve como uma ferramenta para coletar votos. A lógica principal está contida no arquivo main.go, que inicia um servidor da Web e processa solicitações do usuário.

A conexão com o banco de dados é configurada usando variáveis de ambiente, que você configura ao criar o serviço do Cloud Run. Essas variáveis informam ao aplicativo como se conectar à sua instância do AlloyDB, incluindo o nome do banco de dados, o usuário, a senha e o endereço IP da instância. O código usa essas variáveis para estabelecer uma conexão segura com o banco de dados do AlloyDB.

Repositório do código

O repositório alloydb-auth-proxy contém o proxy de autenticação do AlloyDB, uma ferramenta que ajuda você a se conectar com segurança às suas instâncias do AlloyDB. O repositório também inclui bibliotecas e exemplos relacionados, como o aplicativo Go usado neste guia de início rápido.

Não é necessário ter o projeto alloydb-auth-proxy inteiro para se conectar ao AlloyDB pelo Cloud Run. O comando cloudshell_open clona todo o repositório para sua conveniência, mas os únicos arquivos usados para criar o contêiner para este guia de início rápido estão localizados no diretório examples/go.

Antes de começar

  1. Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
  2. In the Google Cloud console, on the project selector page, select or create a Google Cloud project.

    Roles required to select or create a project

    • Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
    • Create a project: To create a project, you need the Project Creator role (roles/resourcemanager.projectCreator), which contains the resourcemanager.projects.create permission. Learn how to grant roles.

    Go to project selector

  3. Verify that billing is enabled for your Google Cloud project.

  4. In the Google Cloud console, on the project selector page, select or create a Google Cloud project.

    Roles required to select or create a project

    • Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
    • Create a project: To create a project, you need the Project Creator role (roles/resourcemanager.projectCreator), which contains the resourcemanager.projects.create permission. Learn how to grant roles.

    Go to project selector

  5. Verify that billing is enabled for your Google Cloud project.

  6. Ative as APIs do Cloud necessárias para executar um aplicativo de exemplo do AlloyDB para PostgreSQL no Cloud Run.

    Ativar as APIs

    1. Na etapa Confirmar projeto, clique em Próxima para confirmar o nome do projeto em que você vai fazer mudanças.

    2. Na etapa Ativar APIs, clique em Ativar para ativar o seguinte:

      • API AlloyDB
      • API Cloud Run Admin
      • API Compute Engine
      • API Cloud Build
      • API Container Registry
      • API Service Networking
      • API Cloud Resource Manager
  7. Verifique se você tem um cluster do AlloyDB e uma instância principal. Para mais informações, consulte Criar um cluster e a instância principal dele.
  8. Conectar-se à instância e criar um banco de dados

    1. Se você não estiver na página Visão geral do cluster recém-criado, acesse a página Clusters no Google Cloud console.

      Acessar Clusters

    2. Para mostrar a página Visão geral do cluster, clique no nome do cluster my-cluster.

    3. No menu de navegação, clique em AlloyDB Studio.

    4. Na lista Banco de dados da página Fazer login no AlloyDB Studio, selecione postgres.

    5. Na lista suspensa Usuário, selecione postgres.

    6. No campo Senha, insira a senha que você criou em Criar um cluster e a instância principal dele.

    7. Clique em Autenticar. O painel Explorer mostra uma lista dos objetos no seu banco de dados.

    8. Na guia Editor 1, crie um banco de dados:

      CREATE DATABASE quickstart_db;
      
    9. Clique em Executar. Aguarde a mensagem Statement executed successfully aparecer no painel Resultados.

    Encontrar seu código de projeto

    1. Acesse a página Painel no console Google Cloud .

      Ir para o painel

    2. Encontre o ID do projeto no card Informações do projeto.

    3. Anote o ID do projeto. Você vai precisar dele na próxima etapa deste guia de início rápido.

    Preencher o Artifact Registry com uma imagem do aplicativo de amostra

    1. No console do Google Cloud , abra o Cloud Shell.

      Abra o Cloud Shell

    2. No editor do Cloud Shell, use o comando a seguir para clonar o repositório com o código do aplicativo de amostra do GitHub:

      cloudshell_open --repo_url \
      "https://github.com/GoogleCloudPlatform/alloydb-auth-proxy" \
      --dir \
      "examples/go" \
      --force_new_clone
    3. Crie um repositório no Artifact Registry para imagens do Docker:

      gcloud artifacts repositories create cloud-run-source-deploy --location us-central1 --repository-format=docker --project PROJECT_ID

      Substitua PROJECT_ID pelo ID do seu projeto.

    4. Na caixa de diálogo Autorizar o Cloud Shell, clique em Autorizar. Essa solicitação não aparece se você já tiver feito essa etapa.

    5. Para criar um contêiner do Docker e publicá-lo no Artifact Registry, use o seguinte comando:

       gcloud builds submit --tag  us-central1-docker.pkg.dev/PROJECT_ID/cloud-run-source-deploy/run-sql --project PROJECT_ID

      Substitua PROJECT_ID pelo ID do seu projeto.

      O código do aplicativo de amostra para este guia de início rápido está localizado no diretório examples/go do repositório GoogleCloudPlatform/alloydb-auth-proxy do GitHub. O comando cloudshell_open na etapa anterior clona automaticamente esse repositório e abre o diretório correto para você.

    Encontrar o endereço IP da nova instância

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

      Acessar Clusters

    2. Encontre a linha na tabela em que o Nome do recurso é my-primary.

    3. Anote o endereço IP privado dessa linha. Você vai precisar dele na próxima etapa deste guia de início rápido.

      O formato de exemplo do endereço IP é 172.19.209.2:5432.

    Criar um serviço para o Cloud Run

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

      Acessar o Cloud Run

    2. Na guia Serviços, clique em Implantar contêiner.

    3. Na página Criar serviço, selecione a opção Implantar uma revisão de uma imagem de contêiner atual.

    4. No campo URL da imagem do contêiner, clique em Selecionar.

    5. No painel Selecionar imagem do contêiner, execute estas etapas:

      1. Selecione a guia Artifact Registry.
      2. Abra us-central1-docker.pkg.dev/PROJECT_ID/cloud-run-source-deploy.
      3. Abra run-sql.
      4. Selecione a imagem mais recente.
      5. Clique em Selecionar.
    6. No campo Nome da conta de serviço, insira quickstart-service.

    7. Verifique se us-central1 (Iowa) está selecionado por padrão na lista Região.

    8. Na seção Autenticação, selecione Permitir acesso público.

    9. Verifique se a opção A CPU é alocada somente durante o processamento da solicitação está selecionada na seção Alocação de CPU e preços.

    10. Abra a seção Contêineres, volumes, rede, segurança.

    11. Na guia Contêineres, selecione a guia Variáveis e secrets e siga estas etapas:

      1. Na seção Variáveis de ambiente, clique em Adicionar variável.

      2. Insira o seguinte nos campos Name e Value:

        • DB_NAME: quickstart_db
        • DB_USER: postgres
        • DB_PASS: a senha inserida quando você criou o cluster.
        • DB_PORT: 5432
        • INSTANCE_HOST: o endereço IP da instância principal do cluster, que você encontrou em Encontrar o endereço IP da nova instância. Não inclua o número da porta. Por exemplo, defina como 172.19.209.2, e não 172.19.209.2:5432.
    12. Mude da guia Contêineres para a guia Rede e conclua as etapas a seguir:

      1. Marque a caixa de seleção Conectar a uma VPC para tráfego de saída.

      2. Selecione a opção Enviar tráfego diretamente para uma VPC.

      3. Na lista suspensa Rede, escolha o valor default.

      4. Na lista suspensa Sub-rede, verifique se o valor default está selecionado.

    13. Clique em Criar para criar o serviço do Cloud Run.

      Depois que o serviço do Cloud Run for implantado, a página quickstart-service vai mostrar o URL do aplicativo de amostra no campo URL.

      O aplicativo usa o AlloyDB como repositório de dados.

    Ver o aplicativo de exemplo

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

      Acessar o Cloud Run

    2. Na página quickstart-service, clique em Copiar para a área de transferência para copiar o URL do aplicativo.

    3. Em uma nova guia do navegador, cole o URL do aplicativo copiado e clique em Enter.

    Limpar

    Para evitar cobranças na conta do Google Cloud pelos recursos usados nesta página, siga as etapas abaixo.

    Limpar o cluster

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

      Acessar Clusters

    2. Ao lado do cluster my-cluster que você quer excluir, clique em Ações e depois em Excluir.

    3. Na caixa de diálogo Excluir cluster, digite my-cluster no campo my-cluster para confirmar a exclusão.

    4. Clique em Excluir.

    Limpar o serviço

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

      Acessar o Cloud Run

    2. Marque a caixa de seleção ao lado do nome do serviço do quickstart-service.

    3. Clique em Excluir na parte de cima da página Cloud Run.

    4. Na caixa de diálogo Excluir quickstart-service que aparece, clique em Excluir para confirmar.

    A seguir