Solução de problemas do auxiliar de credenciais e HTTPS das conexões com AWS CodeCommit - AWS CodeCommit

AWS CodeCommit não está mais disponível para novos clientes. Os clientes atuais do AWS CodeCommit podem continuar usando o serviço normalmente. Saiba mais

As traduções são geradas por tradução automática. Em caso de conflito entre o conteúdo da tradução e da versão original em inglês, a versão em inglês prevalecerá.

Solução de problemas do auxiliar de credenciais e HTTPS das conexões com AWS CodeCommit

As informações a seguir podem ajudá-lo a solucionar problemas comuns ao usar o auxiliar de credenciais incluído no AWS CLI e HTTPS para se conectar aos repositórios. CodeCommit

nota

Embora o auxiliar de credenciais seja um método compatível para se conectar CodeCommit usando acesso federado, um provedor de identidade ou credenciais temporárias, o método recomendado é instalar e usar o utilitário. git-remote-codecommit Para ter mais informações, consulte Etapas de configuração para conexões HTTPS com o AWS CodeCommit com git-remote-codecommit.

Eu recebo um erro ao executar o comando git config para configurar o assistente de credenciais

Problema: ao tentar executar o comando git config para configurar o auxiliar de credenciais para se comunicar com um CodeCommit repositório, você vê um erro informando que há poucos argumentos ou um prompt de uso sugerindo comandos e sintaxe do Git config.

Possíveis correções: o motivo mais comum para esse erro é que aspas simples são usadas para o comando em um sistema operacional Windows ou aspas duplas são usadas para o comando em um sistema operacional Linux, macOS ou Unix. A sintaxe correta é a seguinte:

  • Windows: git config --global credential.helper "!aws codecommit credential-helper $@"

  • Linux, macOS ou Unix: git config --global credential.helper '!aws codecommit credential-helper $@'

Eu vejo um erro ao ler o nome do usuário ao tentar clonar um repositório

Problema: Ao tentar clonar um repositório usando o auxiliar de credenciais, você vê um erro informando que o sistema não conseguiu ler o nome de usuário do repositório. URL

Possíveis correções: o motivo mais comum para esse erro é que o arquivo.gitconfig não foi criado ou configurado corretamente no seu computador. Abra seu arquivo.gitconfig e verifique se o auxiliar de credenciais está configurado corretamente. Se você estiver em um computador executando Linux, macOS ou Unix, verifique também se o valor de $HOME está definido corretamente para o seu sistema.

Recebo um erro de comando não encontrado no Windows ao usar o assistente de credenciais

Problema: Depois de atualizar o AWS CLI, as conexões auxiliares de credenciais com os CodeCommit repositórios falham com. aws codecommit credential-helper $@ get: aws: command not found

Causa: O motivo mais comum para esse erro é que sua AWS CLI versão foi atualizada para uma versão que usa Python 3. Há um problema conhecido com o MSI pacote. Para verificar se você tem uma das versões afetadas, abra uma linha de comando e execute o seguinte comando: aws --version

Se a saída da versão do Python começar com 3, você terá uma versão afetada. Por exemplo: .

aws-cli/1.16.62 Python/3.6.2 Darwin/16.7.0 botocore/1.12.52

Correções possíveis: Para contornar este problema, siga uma das seguintes opções:

  • Instale e configure o AWS CLI no Windows usando Python e pip em vez do. MSI Para obter mais informações, consulte Instalar Python, pip e the no AWS CLI Windows.

  • Edite manualmente o arquivo .gitconfig para alterar a seção [credential] para apontar explicitamente para aws.cmd em seu computador local. Por exemplo: .

    [credential] helper = !"\C:\\Program Files\\Amazon\\AWSCLI\\bin\\aws.cmd\" codecommit credential-helper $@ UseHttpPath = true
  • Execute o git config comando para atualizar seu .gitconfig arquivo para aws.cmd referenciar explicitamente e atualize manualmente sua variável de PATH ambiente para incluir o caminho para o comando conforme necessário. Por exemplo: .

    git config --global credential.helper "!aws.cmd codecommit credential-helper $@" git config --global credential.UseHttpPath true

Sou solicitado a fornecer um nome de usuário quando me conecto a um repositório CodeCommit

Problema: Quando você tenta usar o auxiliar de credenciais para se comunicar com um CodeCommit repositório, aparece uma mensagem solicitando seu nome de usuário.

Possíveis correções: configure seu AWS perfil ou verifique se o perfil que você está usando é aquele com o qual você configurou para trabalhar CodeCommit. Para obter mais informações sobre a configuração, consulte Etapas de configuração para conexões HTTPS a repositórios do AWS CodeCommit no Linux, macOS ou Unix com o assistente de credenciais da AWS CLI ou Etapas de configuração para conexões HTTPS a repositórios do AWS CodeCommit no Windows com o assistente de credenciais da AWS CLI.. Para obter mais informações sobre IAM chaves de acesso e chaves secretas, consulte Gerenciando chaves de acesso para IAM usuários e Como faço para obter credenciais?

Git para macOS: eu configurei o assistente de credenciais com êxito, mas agora o acesso ao meu repositório é negado (403)

Problema: no macOS, o assistente de credenciais parece não acessar ou usar suas credenciais como esperado. Isso pode ser causado por dois problemas diferentes:

  • O AWS CLI está configurado para um Região da AWS diferente daquele em que o repositório existe.

  • O utilitário Keychain Access salvou credenciais já expiradas.

Possíveis correções: Para verificar se o AWS CLI está configurado para a região correta, execute o aws configure comando e revise as informações exibidas. Se o CodeCommit repositório estiver em um Região da AWS local diferente do mostrado para o AWS CLI, você deverá executar o aws configure comando e alterar os valores para aqueles apropriados para aquela região. Para ter mais informações, consulte Etapa 1: configuração inicial do CodeCommit.

A versão padrão do Git lançada para OS X e macOS usa o utilitário Acesso às Chaves para salvar as credenciais geradas. Por motivos de segurança, a senha gerada para acessar seu CodeCommit repositório é temporária, portanto, as credenciais armazenadas no chaveiro param de funcionar após cerca de 15 minutos. Se você estiver acessando o Git somente com CodeCommit, tente o seguinte:

  1. No terminal, execute o comando git config para localizar o arquivo de configuração do Git (gitconfig) em que o utilitário Keychain Access está definido. Dependendo do seu sistema local e de suas preferências, você pode ter mais de um arquivo gitconfig.

    git config -l --show-origin | grep credential

    Na saída desse comando, procure resultados semelhantes a:

    file:/path/to/gitconfig credential.helper=osxkeychain

    O arquivo listado no início dessa linha é o arquivo de configuração do Git que você deve editar.

  2. Para editar o arquivo de configuração do Git, use um editor de texto simples e execute o seguinte comando:

    nano /usr/local/git/etc/gitconfig
  3. Modifique a configuração usando uma das seguintes estratégias:

    • Comente ou exclua a seção de credenciais que contém helper = osxkeychain. Por exemplo: .

      # helper = osxkeychain
    • Atualize as seções assistente de credenciais aws credential helper e osxkeychain para ter contexto. Por exemplo, se osxkeychain for usado para se autenticar GitHub em:

      [credential "https://git-codecommit.us-east-1.amazonaws\.com"] helper = !aws --profile CodeCommitProfile codecommit credential-helper $@ UseHttpPath = true [credential "https://github.com"] helper = osxkeychain

      Nessa configuração, o Git usará o assistente osxkeychain quando o host remoto corresponder a "https://github.com" e ao assistente de credenciais quando o host remoto corresponder a "https://git-codecommit\.us-east-1\.amazonaws.com”.

    • Inclua um assistente de string vazio antes do assistente de credenciais. Por exemplo, para não usar o osxkeychain auxiliar ao usar o perfil chamado CodeCommitProfile com oCLI:

      [credential] helper = helper = !aws --profile CodeCommitProfile codecommit credential-helper $@ UseHttpPath = true
      dica

      Você também pode configurar a linha após a linha auxiliar de string vazia para não corresponder CodeCommit se quiser que ela exclua todos os perfis:

      helper = !aws codecommit credential-helper $@

    Como alternativa, se você deseja continuar a usar o utilitário Keychain Access para armazenar em cache as credenciais para outros repositórios Git, modifique o cabeçalho em vez de comentar a linha. Por exemplo, para permitir credenciais em cache GitHub, você pode modificar o cabeçalho da seguinte forma:

    [credential "https://github.com"] helper = osxkeychain

Se você estiver acessando outros repositórios com o Git, você pode configurar o utilitário Keychain Access para que ele não forneça credenciais para seus repositórios. CodeCommit Como configurar o utilitário Acesso às Chaves:

  1. Abra o utilitário Acesso às Chaves. (Você pode usar o Finder para localizá-lo.)

  2. Procure git-codecommit.us-east-2.amazonaws.com e substitua us-east-2 com o Região da AWS local onde o repositório existe. Destaque a linha, abra o menu de contexto (clique com o botão direito do mouse) e escolha Obter Informações.

  3. Escolha a guia Controle de Acesso.

  4. Em Confirmar antes de permitir o acesso, escolha git-credential-osxkeychain e, em seguida, selecione o sinal de menos para removê-la da lista.

    nota

    Após remover git-credential-osxkeychain da lista, você verá uma caixa de diálogo sempre que executar um comando do Git. Escolha Negar para continuar. Se você achar os pop-ups um incômodo, aqui estão algumas alternativas:

Se quiser que o Git pare de usar o utilitário Keychain Access totalmente, você poderá configurar o Git para parar de usar osxkeychain como o assistente de credenciais. Por exemplo, se você abrir um terminal e executar o comando git config --system credential.helper e ele retornar osxkeychain, o Git estará configurado para usar o utilitário Keychain Access. Você poderá alterar isso executando o seguinte comando:

git config --system --unset credential.helper

Lembre-se de que executar esse comando com a --system opção altera o comportamento do Git em todo o sistema para todos os usuários, e isso pode ter consequências não intencionais para outros usuários ou para outros repositórios se você estiver usando outros serviços de repositório além do. CodeCommit Lembre-se também de que essa abordagem pode exigir o uso de sudo e que sua conta pode não ter permissões suficientes do sistema para aplicar essa alteração. Verifique se o comando foi aplicado com êxito executando o comando git config --system credential.helper novamente. Para obter mais informações, consulte Personalização do Git – Configuração do Git e este artigo no Stack Overflow.

Git para Windows: eu instalei o Git para Windows, mas o acesso ao meu repositório é negado (403)

Problema: no Windows, o assistente de credenciais parece não acessar ou usar suas credenciais como esperado. Isso pode ser causado por diferentes problemas:

  • O AWS CLI está configurado para um Região da AWS diferente daquele em que o repositório existe.

  • Por padrão, o Git para Windows instala um utilitário Git Credential Manager que não é compatível com CodeCommit conexões que usam o auxiliar de credenciais. AWS Quando instalado, ele faz com que as conexões com o repositório falhem, mesmo que o auxiliar de credenciais tenha sido instalado com o AWS CLI e configurado para conexões com o. CodeCommit

  • Algumas versões do Git para Windows podem não estar em total conformidade com RFC2617 e RFC4559, o que pode causar problemas com as credenciais do Git e com o auxiliar de credenciais incluído no. AWS CLI Para obter mais informações, consulte Version 2.11.0(3) does not ask for username/password.

Correções possíveis:

  • Se você estiver tentando usar o auxiliar de credenciais incluído no AWS CLI, considere conectar-se com as credenciais do Git HTTPS em vez de usar o auxiliar de credenciais. As credenciais do Git configuradas para seu IAM usuário são compatíveis com o Gerenciador de Credenciais do Git para Windows, ao contrário do auxiliar de credenciais do. AWS CodeCommit Para ter mais informações, consulte Para usuários de HTTPS usando credenciais do Git.

    Se você quiser usar o auxiliar de credenciais, para verificar se ele AWS CLI está configurado corretamente Região da AWS, execute o aws configure comando e revise as informações exibidas. Se o CodeCommit repositório estiver em um Região da AWS local diferente do mostrado para o AWS CLI, você deverá executar o aws configure comando e alterar os valores para aqueles apropriados para aquela região. Para ter mais informações, consulte Etapa 1: configuração inicial do CodeCommit.

  • Se possível, desinstale e reinstale o Git para Windows. Ao instalar o Git para Windows, desmarque a caixa de seleção com a opção de instalar o utilitário Git Credential Manager. Esse gerenciador de credenciais não é compatível com o assistente de credenciais do AWS CodeCommit. Se você instalou o Git Credential Manager ou outro utilitário de gerenciamento de credenciais e não deseja desinstalá-lo, você pode modificar seu .gitconfig arquivo e adicionar gerenciamento de credenciais para: CodeCommit

    1. Abra o Painel de Controle, escolha Gerenciador de Credenciais e remova todas as credenciais armazenadas para. CodeCommit

    2. Abra o arquivo .gitconfig em um editor de texto simples, como o Bloco de Notas.

      nota

      Se você trabalha com vários perfis do Git, talvez tenha arquivos .gitconfig locais e globais. Certifique-se de editar o arquivo apropriado.

    3. Adicione a seguinte seção ao arquivo .gitconfig:

      [credential "https://git-codecommit.*.amazonaws.com"] helper = !aws codecommit credential-helper $@ UseHttpPath = true
    4. Salve o arquivo e abra uma nova sessão de linha de comando antes de tentar se conectar novamente.

    Você também pode usar essa abordagem se quiser usar o auxiliar de credenciais para AWS CodeCommit se conectar a CodeCommit repositórios e outro sistema de gerenciamento de credenciais ao se conectar a outros repositórios hospedados, como repositórios. GitHub

    Para restaurar o assistente de credenciais usado como padrão, você pode usar a opção --system em vez de --global ou --local ao executar o comando git config.

  • Se você estiver usando credenciais do Git em um computador Windows, tente contornar qualquer problema de RFC não conformidade incluindo o nome de usuário da sua credencial do Git como parte da cadeia de conexão. Por exemplo, para contornar o problema e clonar um repositório chamado MyDemoRepo na região Leste dos EUA (Ohio):

    git clone https://Your-Git-Credential-Username@git-codecommit.us-east-2.amazonaws.com/v1/repos/MyDemoRepo my-demo-repo
    nota

    Essa abordagem não funcionará se você tiver um caractere @ no seu nome de usuário das credenciais do Git. Você deve URL codificar em -code (também conhecido como URL escape ou codificação percentual) o caractere.