Autorizar a CLI gcloud

Para acessar o Google Cloud, é necessário autorizar a Google Cloud CLI. Nesta página, mostramos as opções de autorização disponíveis e mostramos como gerenciar as contas que você usa para autorização. Se você estiver usando uma instância do Compute Engine ou o Cloud Shell, não será necessário autorizar a CLI gcloud.

Tipos de contas

Para conceder autorização à CLI gcloud para acessar o Google Cloud, use uma conta de usuário ou uma conta de serviço.

Uma conta de usuário é uma conta do Google Cloud que permite que os usuários finais se autentiquem no seu aplicativo. Na maioria dos casos de uso comum, especialmente ao usar a CLI gcloud de forma interativa, a conta de usuário é a melhor prática.

Uma conta de serviço é uma conta do Google Cloud associada ao seu projeto doGoogle Cloud , e não a um usuário específico. É possível usar a conta de serviço integrada disponível ao usar funções do Cloud Run, App Engine, Compute Engine ou Google Kubernetes Engine. Recomenda-se usar uma conta de serviço para executar scripts da CLI gcloud em várias máquinas.

Escolher um tipo de autorização

É necessário autorizar a Google Cloud CLI a gerenciar recursos do Google Cloud. A CLI do Google Cloud e o Google Cloud usam o OAuth2 para autenticação e autorização.

Escolha um dos seguintes tipos de autorização:

Tipo Descrição
Conta de usuário Recomendado se você estiver usando a CLI gcloud na linha de comando ou se estiver escrevendo scripts com a CLI gcloud para uso em uma única máquina.
Conta de serviço Opção recomendada se você estiver instalando e configurando a CLI gcloud como parte de um processo de implantação de máquinas em produção ou para uso em instâncias de máquina virtual do Compute Engine em que todos os usuários tenham acesso ao root.

Para mais informações sobre a autenticação e o Google Cloud, consulte a Visão geral da autenticação.

Autorizar com uma conta de usuário

Esta seção descreve como autorizar com uma conta de usuário.

Como autenticar com uma Conta do Google

Use os seguintes comandos da CLI gcloud para autorizar o acesso com uma conta de usuário:

Comando Descrição
gcloud init Autoriza o acesso e executa outras etapas de configuração comuns.
gcloud auth login Autoriza apenas o acesso.

Durante a autorização, esses comandos recebem credenciais de conta do Google Cloud e as armazenam no sistema local. A conta especificada passa a ser a conta ativa na configuração. A CLI gcloud usa as credenciais armazenadas para acessar o Google Cloud. É possível ter quantas contas você quiser com credenciais armazenadas em uma única instalação da CLI gcloud, mas apenas uma conta permanece ativa por vez.

Executar gcloud init

gcloud init autoriza o acesso e executa outras etapas comuns de configuração. O gcloud init usa um fluxo de autorização baseado na Web para autenticar a conta de usuário e conceder permissões de acesso.

Para autorizar o acesso e executar outras etapas comuns de configuração:

  1. Execute gcloud init:

    gcloud init
    

    Ou para impedir o comando de abrir automaticamente um navegador da Web:

    gcloud init --console-only
    

    Usar a sinalização --console-only é útil se você estiver executando o comando em um sistema remoto que usa ssh e não tem acesso a um navegador nesse sistema. Nesse caso, abra manualmente o URL fornecido em um navegador no sistema local para concluir o processo de autorização.

  2. Siga o fluxo de autorização baseado no navegador para autenticar a conta e conceder permissões de acesso.

Para mais informações sobre gcloud init, consulte Como inicializar a CLI gcloud.

Executar o gcloud auth login

A execução de gcloud auth login autoriza apenas a conta de usuário. Para autorizar o acesso sem realizar outras etapas de configuração, use uma das opções a seguir.

  • Se você quiser autorizar a CLI gcloud em uma máquina com um navegador, siga estas etapas.

    1. Autorize a CLI gcloud:

      gcloud auth login
      
    2. Siga o fluxo de autorização baseado no navegador para autenticar a conta e conceder permissões de acesso.

  • Se você quiser autorizar a CLI gcloud em uma máquina que não tem um navegador e puder instalar a CLI gcloud em outra máquina com um navegador, use a flag --no-browser.

    1. Autorize a CLI gcloud:

      gcloud auth login --no-browser
      
    2. Copie o comando longo que começa com gcloud auth login --remote-bootstrap=".

    3. Cole e execute esse comando na linha de comando de uma máquina diferente e confiável que tenha instalações locais de um navegador da Web e da ferramenta CLI gcloud versão 372.0 ou mais recente.

    4. Copie a saída do URL longo da máquina com o navegador da Web.

    5. Cole o URL longo de volta à primeira máquina, no prompt "Enter the output of the above command" e pressione Enter para concluir a autorização.

  • Se você quiser autorizar a CLI gcloud em uma máquina que não tem um navegador e não puder instalar a CLI gcloud em outra máquina com um navegador, use a flag --no-launch-browser. A flag --no-launch-browser impede que o comando abra automaticamente um navegador da Web.

    1. Autorize a CLI gcloud:

      gcloud auth login --no-launch-browser
      
    2. Copie o URL longo que começa com https://accounts.google.com/o/oauth2/auth...

    3. Cole este URL no navegador de uma máquina confiável diferente que tenha um navegador da Web.

    4. Copie o código de autorização da máquina com o navegador da Web.

    5. Cole o código de autorização na primeira máquina no prompt "Enter verification code" e pressione Enter para concluir a autorização.

  • Se você já tiver um token de acesso, use um dos seguintes métodos para transmiti-lo à CLI gcloud:

    • Armazene o token de acesso em um arquivo e defina o caminho dele usando a flag --access-token-file.
    • Armazene o token de acesso em um arquivo e defina o caminho dele na propriedade auth/access_token_file.
    • Defina a variável de ambiente CLOUDSDK_AUTH_ACCESS_TOKEN como o valor do token de acesso.

Como autenticar com a federação de identidade do força de trabalho

Esta seção descreve como fazer login na CLI gcloud usando a federação de identidade de colaboradores.

Login baseado no navegador da CLI gcloud

Para fazer login na CLI gcloud usando um fluxo de login baseado em navegador, faça o seguinte:

  1. Crie um arquivo de configuração de login.

    Para criar o arquivo de configuração de login, execute o comando a seguir. Também é possível ativar o arquivo como padrão para a CLI gcloud usando a flag --activate.

    gcloud iam workforce-pools create-login-config \
        locations/global/workforcePools/WORKFORCE_POOL_ID/providers/WORKFORCE_PROVIDER_ID \
        --output-file=LOGIN_CONFIG_FILE

    Substitua:

    • WORKFORCE_POOL_ID: o ID do pool de identidade da força de trabalho
    • WORKFORCE_PROVIDER_ID: o ID do provedor do pool de identidade da força de trabalho
    • LOGIN_CONFIG_FILE: um caminho para o arquivo de configuração de login especificado. Por exemplo, login.json.

    O arquivo contém os endpoints usados pela CLI gcloud para ativar o fluxo de autenticação baseado em navegador e definir o público como o IdP configurado no provedor do pool de identidade dos colaboradores. O arquivo não contém informações confidenciais.

    A saída será assim:

    {
      "type": "external_account_authorized_user_login_config",
      "audience": "//iam.googleapis.com/locations/global/workforcePools/WORKFORCE_POOL_ID/providers/WORKFORCE_PROVIDER_ID",
      "auth_url": "https://auth.cloud.google/authorize",
      "token_url": "https://sts.googleapis.com/v1/oauthtoken",
      "token_info_url": "https://sts.googleapis.com/v1/introspect",
    }

  2. Faça login usando a autenticação baseada no navegador.

    Para usar a autenticação de login baseada em navegador, use um dos seguintes métodos:

    • Se você usou a flag --activate ao criar o arquivo de configuração ou ativou esse arquivo com gcloud config set auth/login_config_file, a gcloud CLI fará uso dele automaticamente:

      gcloud auth login
    • Para fazer login especificando o local do arquivo de configuração, execute o seguinte comando:

      gcloud auth login --login-config=LOGIN_CONFIG_FILE
    • Para usar uma variável de ambiente para especificar o local do arquivo de configuração, defina CLOUDSDK_AUTH_LOGIN_CONFIG_FILE como o caminho de configuração.

Para interromper o uso do arquivo de configuração de login, faça o seguinte:

  • Se você usou a flag --activate ao criar o arquivo de configuração ou ativou esse arquivo com gcloud config set auth/login_config_file, execute o seguinte comando para cancelar a definição:

    gcloud config unset auth/login_config_file
  • Limpe a variável de ambiente CLOUDSDK_AUTH_LOGIN_CONFIG_FILE, se ela estiver definida.

Login headless da CLI gcloud

Para fazer login na gcloud CLI usando um fluxo headless, faça o seguinte:

OIDC

  1. Faça login de um usuário no app do IdP e receba o token OIDC.

    Para mais informações sobre como conseguir o token, consulte a documentação do OIDC do seu IdP.

  2. Salve o token OIDC retornado pelo IdP em um local seguro da máquina local.

  3. Gere um arquivo de configuração executando o seguinte comando:

    gcloud iam workforce-pools create-cred-config \
        locations/global/workforcePools/WORKFORCE_POOL_ID/providers/PROVIDER_ID \
        --subject-token-type="urn:ietf:params:oauth:token-type:id_token" \
        --credential-source-file="PATH_TO_OIDC_ID_TOKEN" \
        --workforce-pool-user-project="WORKFORCE_POOL_USER_PROJECT" \
        --output-file="config.json"
    

Substitua:

  • WORKFORCE_POOL_ID: o ID do pool de colaboradores
  • PROVIDER_ID: o ID do provedor
  • PATH_TO_OIDC_TOKEN: o caminho para o arquivo de credencial do IdP OIDC
  • WORKFORCE_POOL_USER_PROJECT: o número do projeto associado ao projeto do usuário dos pools de forças de trabalho

O principal precisa ter a permissão serviceusage.services.use neste projeto.

Quando você executa o comando, ele gera um arquivo de configuração IdP do OIDC formatado da seguinte maneira:

{
  "type": "external_account",
  "audience": "//iam.googleapis.com/locations/global/workforcePools/WORKFORCE_POOL_ID/providers/PROVIDER_ID",
  "subject_token_type": "urn:ietf:params:oauth:token-type:id_token",
  "token_url": "https://sts.googleapis.com/v1/token",
  "workforce_pool_user_project": "WORKFORCE_POOL_USER_PROJECT",
  "credential_source": {
    "file": "PATH_TO_OIDC_CREDENTIALS_FILE"
  }
}

SAML

  1. Faça login de um usuário no app do IdP e receba a declaração SAML.

    Para saber como receber a declaração SAML do IdP, consulte a documentação do IdP.

  2. Salve a resposta SAML retornada pelo IdP em um local seguro da máquina local e armazene o caminho da seguinte maneira:

    SAML_ASSERTION_PATH=SAML_ASSERTION_PATH
    
  3. Para gerar um arquivo de configuração, execute o seguinte comando:

    gcloud iam workforce-pools create-cred-config \
        locations/global/workforcePools/WORKFORCE_POOL_ID/providers/WORKFORCE_PROVIDER_ID \
        --subject-token-type="urn:ietf:params:oauth:token-type:saml2" \
        --credential-source-file="SAML_ASSERTION_PATH"  \
        --workforce-pool-user-project="PROJECT_ID"  \
        --output-file="config.json"
    

    Substitua:

    • WORKFORCE_PROVIDER_ID: o ID do provedor da força de trabalho criado anteriormente neste guia.
    • WORKFORCE_POOL_ID: o ID do pool de forças de trabalho que você criou anteriormente neste guia.
    • SAML_ASSERTION_PATH: o caminho do arquivo de declaração SAML.
    • PROJECT_ID: o ID do projeto;

    O arquivo de configuração gerado é semelhante ao seguinte:

    {
      "type": "external_account",
      "audience": "//iam.googleapis.com/locations/global/workforcePools/WORKFORCE_POOL_ID/providers/WORKFORCE_PROVIDER_ID",
      "subject_token_type": "urn:ietf:params:oauth:token-type:saml2",
      "token_url": "https://sts.googleapis.com/v1/token",
      "credential_source": {
        "file": "SAML_ASSERTION_PATH"
      },
      "workforce_pool_user_project": "PROJECT_ID"
    }
    

Para fazer login no gcloud usando a troca de tokens, execute o seguinte comando:

gcloud auth login --cred-file="config.json"

Em seguida, o gcloud troca suas credenciais de IdP por tokens de acesso temporários do Google Cloud , permitindo que você faça outras chamadas de gcloud para o Google Cloud.

O resultado será assim:

Authenticated with external account user credentials for:
[principal://iam.googleapis.com/locations/global/workforcePools/WORKFORCE_POOL_ID/subject/USER_ID].

Para listar as contas credenciadas e a conta ativa no momento, execute o seguinte comando:

gcloud auth list

Autorizar com uma conta de serviço

O comando gcloud auth login pode autorizar o acesso com uma conta de serviço usando um arquivo de credenciais armazenado no sistema de arquivos local. Essa credencial pode ser uma credencial de usuário com permissão para representar a conta de serviço, um arquivo de configuração de credencial para a Federação de identidade da carga de trabalho ou uma chave de conta de serviço.

Autorizar uma conta de serviço usando a representação da conta de serviço

Para autorizar a CLI gcloud a usar credenciais de conta de serviço falsificadas, faça o seguinte:

  1. No console do Google Cloud , acesse a página "Contas de serviço".

    Acessar a página "Contas de serviço"

  2. Escolha uma conta atual ou crie uma nova clicando em Criar conta de serviço.

  3. Para garantir que o principal tenha a permissão necessária a fim de representar uma conta de serviço, peça ao administrador para conceder a ele o papel do IAM de criador de tokens da conta de serviço (roles/iam.serviceAccountTokenCreator) na conta de serviço. 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 a permissão iam.serviceAccounts.getAccessToken que é necessária para representar uma conta de serviço.

    O administrador também pode conceder essa permissão ao principal com papéis personalizados ou outros papéis predefinidos.

  4. Autorize a CLI gcloud com sua identidade de usuário executando gcloud auth login.

  5. Para configurar a CLI gcloud para usar a identidade e o acesso fornecidos por uma conta de serviço por padrão, use o comando de configuração da CLI gcloud:

    gcloud config set auth/impersonate_service_account SERVICE_ACCT_EMAIL
    
  6. Para deixar de usar as credenciais de conta de serviço falsificadas com a CLI gcloud por padrão, desative a flag com o comando de configuração da CLI gcloud:

    gcloud config unset auth/impersonate_service_account
    

Autorizar uma conta de serviço usando a federação de identidade da carga de trabalho

Para autorizar a CLI gcloud com uma conta de serviço usando credenciais externas da federação de identidade da carga de trabalho, faça o seguinte:

  1. No console do Google Cloud , acesse a página "Contas de serviço".

    Acessar a página "Contas de serviço"

  2. Escolha uma conta atual ou crie uma nova clicando em Criar conta de serviço.

  3. Crie um arquivo de configuração de credenciais para a federação de identidade da carga de trabalho seguindo as instruções do provedor de identidade compatível.

  4. Para ativar a conta de serviço, execute gcloud auth login com a flag --cred-file:

    gcloud auth login --cred-file=CONFIGURATION_FILE
    

    Substitua CONFIGURATION_FILE pelo caminho de um arquivo de configuração de credenciais para a federação de identidade da carga de trabalho.

Autorizar uma conta de serviço usando uma chave

Para autorizar a CLI gcloud com uma conta de serviço usando uma chave de conta de serviço, faça o seguinte:

  1. No console do Google Cloud , acesse a página "Contas de serviço".

    Acessar a página "Contas de serviço"

  2. Escolha uma conta atual ou crie uma nova clicando em Criar conta de serviço.

  3. Para criar chaves de conta de serviço, consulte as instruções do IAM para Criar uma chave de conta de serviço.

  4. Para ativar a conta de serviço, execute gcloud auth login com a flag --cred-file:

    gcloud auth login --cred-file=KEY_FILE
    

    Substitua KEY_FILE pelo caminho para um arquivo de chave da conta de serviço.

Listar contas

Para listar as contas com credenciais armazenadas no sistema local, execute gcloud auth list:

gcloud auth list

A CLI gcloud lista as contas e mostra qual delas está ativa:

Credentialed accounts:
 - user-1@gmail.com (active)
 - user-2@gmail.com

Mudar a conta ativa

Para alternar a conta ativa, execute gcloud config set:

gcloud config set account ACCOUNT

em que [ACCOUNT] é o endereço de e-mail completo da conta.

Você também pode alternar entre contas criando uma configuração separada que especifique a conta diferente e alterne entre as configurações:

gcloud config configurations activate CONFIGURATION

Se você quiser alternar a conta usada pela CLI gcloud a cada invocação, modifique a conta ativa usando a flag --account.

Definir a duração da sessão autorizada

Como administrador, você controla por quanto tempo diferentes usuários podem acessar a CLI gcloud sem precisar fazer a autenticação novamente. Por exemplo, é possível forçar usuários com privilégios elevados a fazer uma nova autenticação com mais frequência do que os usuários regulares.

Para mais informações, consulte Definir a duração da sessão dos serviços do Google Cloud .

Revogar credenciais de uma conta

Revogue as credenciais quando quiser impedir o acesso da CLI gcloud por uma conta específica. Não é necessário revogar credenciais para alternar entre contas.

Para revogar as credenciais, execute gcloud auth revoke:

gcloud auth revoke ACCOUNT

Para revogar o acesso da CLI gcloud em todas as máquinas, remova a CLI gcloud da lista de aplicativos que têm acesso à sua conta.

Trabalhar com arquivos de credencial

Encontrar os arquivos de credenciais

Para encontrar o local dos seus arquivos de credenciais, execute gcloud info:

gcloud info

A CLI gcloud imprime informações sobre a instalação. Arquivos de credenciais são armazenados no diretório de configuração do usuário:

User Config Directory: [/home/USERNAME/.config/gcloud]

Configurar o Application Default Credentials

A CLI gcloud oferece suporte ao gerenciamento de credenciais padrão do aplicativo (ADC, na sigla em inglês) com o grupo de comandos gcloud auth application-default. Para disponibilizar as credenciais do usuário ao ADC, execute gcloud auth application-default login:

gcloud auth application-default login

Essas credenciais não são usadas pela CLI gcloud. Para mais maneiras de configurar o ADC, consulte Configurar o Application Default Credentials.

unset GOOGLE_APPLICATION_CREDENTIALS
gcloud config unset auth/impersonate_service_account
gcloud auth application-default login

A seguir