Como usar várias chaves ssh com contas e hosts diferentes

21

eu tenho várias chaves ssh e também tenho conta no bitbucket e no github. como quando eu uso puxar me dá erro

:/var/www/proj$ git pull origin master
conq: repository access denied.
fatal: The remote end hung up unexpectedly

ou se eu ssh o site bitbucket dá erros burro chave pública negada

:~$ ssh [email protected]
Permission denied (publickey).

Como posso resolver isso e usar chaves diferentes com contas diferentes?

    
por Iori 17.03.2013 / 15:38

2 respostas

20

Tudo isso é coletado do website e stackoverflow, espero que isso ajude quem é novo no ssh

para que você possa ter muitas chaves ssh

~/.ssh$ ls
yyy_id_rsa  yyy_id_rsa.pub  id_rsa  id_rsa.pub  known_hosts

Nota: precisamos adicionar ao ssh-agent, provavelmente o id_rsa será adicionado, então precisamos adicionar a outra chave privada

~/.ssh$ ssh-add yyy_id_rsa

agora adicionamos as duas chaves ssh ao ssh-agent

temos um para o bitbucket e outro para o github

então criamos um arquivo de configuração como este

~/.ssh$ nano config
Host bit-yyyuser bitbucket.org
Hostname bitbucket.org
IdentityFile ~/.ssh/yyy_id_rsa
User yyyuser

Host bit-xxxuser bitbucket.org
Hostname bitbucket.org
IdentityFile ~/.ssh/id_rsa
User xxxuser

Host git-xxxuser github.com
Hostname github.com
IdentityFile ~/.ssh/id_rsa
User xxxuser

Observação: estou usando duas chaves diferentes para duas contas diferentes no bitbucket e uma para o github.

Agora precisamos informar ao repositório git qual host usar para que eu obtenha essa chave ssh específica para essa conta específica

altere [email protected]/yyyproject.git para git@bit-yyyuser:yyyuser/yyyproject.git

na pasta do projeto e adicione o url remoto

/var/www/yyyproject$ git remote add bit git@bit-yyyuser:yyyuser/yyyproject.git

em outro projeto

/var/www/xxxproject$ git remote add bitt git@bit-xxxuser:xxxuser/xxxproject.git

agora você pode usar push and pull facilmente

:/var/www/yyyproject$ git pull bit master
From bit-yyyuser:yyyuser/yyyproject
 * branch            master     -> FETCH_HEAD
Already up-to-date.
:/var/www/yyyproject$

e outro projeto

/var/www/xxxproject$ git push bitt ver1
To git@bit-xxxuser:xxxuser/xxxproject.git
 * branch            master     -> FETCH_HEAD
Already up-to-date.
:/var/www/xxxproject$ 

agora eu não tenho o projeto github na máquina local, então precisamos clonar o projeto mas precisamos fazer uma pequena alteração no URL para clonar

nosso URL é assim

[email protected]:xxxuser/python.git

como temos que cloná-lo com chaves específicas, só precisamos mudar o nome do host com o host que definimos

git@git-xxxuser:xxxuser/python.git

conforme definido no arquivo de configuração

e agora podemos clonar

:/var/www/us$ git clone git@git-xxxuser:xxxuser/python.git
Cloning into 'python'...
remote: Counting objects: 75, done.
remote: Compressing objects: 100% (42/42), done.
remote: Total 75 (delta 18), reused 62 (delta 8)
Receiving objects: 100% (75/75), 6.29 KiB, done.
Resolving deltas: 100% (18/18), done.
:/var/www/us$ 

identificamos chaves ssh diferentes para host diferente, uma para git e uma para bitbucket agora o sistema sabe quais chaves ssh devem ser usadas com qual host.

Agora podemos facilmente puxar, empurrar.

    
por Iori 17.03.2013 / 15:38
1

Eu configuro ~/.ssh/config , assim:

Host gitlab-as-thuc  
    HostName git.thuc.com
    User git
    IdentityFile ~/.ssh/id_rsa.thuc
    IdentitiesOnly yes

use o nome do host personalizado em vez do domínio real na URL git:

git remote add thuc git@gitlab-as-thuc:your-repo.git  

Para mais detalhes, por favor leia aqui: link

    
por thucnguyen 17.05.2016 / 17:06