Meilleure façon d'utiliser plusieurs clés privées SSH sur un seul client

873

Je souhaite utiliser plusieurs clés privées pour me connecter à différents serveurs ou à différentes parties du même serveur (mes utilisations sont l'administration système du serveur, l'administration de Git et l'utilisation normale de Git au sein du même serveur). J'ai essayé d'empiler simplement les clés dans les id_rsafichiers en vain.

Apparemment, un moyen simple de le faire est d'utiliser la commande

ssh -i <key location> [email protected] 

C'est assez lourd.

Avez-vous des suggestions sur la façon de procéder un peu plus facilement?

Justin
la source
1
J'ai écrit cet article qui va en profondeur sur les différentes configurations et leurs points forts / défauts.
Raffi

Réponses:

1236

De mon .ssh/config:

Host myshortname realname.example.com
    HostName realname.example.com
    IdentityFile ~/.ssh/realname_rsa # private key for realname
    User remoteusername

Host myother realname2.example.org
    HostName realname2.example.org
    IdentityFile ~/.ssh/realname2_rsa  # different private key for realname2
    User remoteusername

Etc.

Randal Schwartz
la source
25
Merci Randal! J'ai fait quelques recherches dans le fichier .ssh / config et j'ai trouvé ceci: github.com/guides/multiple-github-accounts m'a pointé dans la bonne direction.
Justin
6
C'était une grande aide (en plus de stackoverflow.com/a/3828682/169153 ). Si vous souhaitez utiliser des clés à mastic, suivez ce document ici: blog.padraigkitterick.com/2007/09/16/…
Urda
2
J'ai trouvé ce message très utile. Une erreur que j'ai commise lors de la création du fichier de configuration a été de mettre un fichier .txt dans le dossier .ssh au lieu d'exécuter la commande "touch" pour créer un fichier de configuration.
M_x_r
53
Notez que vous pouvez également spécifier plusieurs IdentityFileentrées pour la même Host, qui sont ensuite essayées dans l'ordre lors de la connexion.
sschuberth
12
Utilisez IdentitiesOnly yespour empêcher ~ / .ssh / id_rsa ou toute autre identité. (C'était à l'origine une modification)
user3338098
372

Vous pouvez demander à ssh d'essayer plusieurs touches successivement lors de la connexion. Voici comment:

$ cat ~/.ssh/config
IdentityFile ~/.ssh/id_rsa
IdentityFile ~/.ssh/id_rsa_old
IdentityFile ~/.ssh/id_ed25519
# ... and so on

$ ssh server.example.com -v
....
debug1: Next authentication method: publickey
debug1: Trying private key: /home/example/.ssh/id_rsa
debug1: read PEM private key done: type RSA
debug1: Authentications that can continue: publickey
debug1: Trying private key: /home/example/.ssh/id_rsa_old
debug1: read PEM private key done: type RSA
....
[server ~]$

De cette façon, vous n'avez pas à spécifier quelle clé fonctionne avec quel serveur. Il utilisera simplement la première clé de travail.

Vous ne devez également saisir une phrase secrète que si un serveur donné est prêt à accepter la clé. Comme vu ci-dessus, ssh n'a pas essayé de demander un mot de passe .ssh/id_rsamême s'il en avait un.

Cela ne surpasse certainement pas une configuration par serveur comme dans les autres réponses, mais au moins vous n'aurez pas à ajouter une configuration pour tous les serveurs auxquels vous vous connectez!

spaceix
la source
13
Il s'agit d'une solution fantastique pour la question posée, mais ne répondait pas tout à fait aux besoins que le demandeur souhaitait. Pour moi, c'était exactement la bonne solution et elle répond parfaitement au besoin de la "meilleure façon d'utiliser plusieurs clés privées SSH sur un seul client".
Wade
2
Cela ne semble pas fonctionner sous la déclaration de l'hôte dans le fichier de configuration
Maksim Luzik
30
Cela ne fonctionne pas bien avec git, comme si vous avez deux clés de déploiement github, la première de la liste est valide et fonctionnera, mais alors github se plaindra que le référentiel ne correspond pas.
Adam Reis
1
Si le serveur SFTP / cible a des politiques de sécurité qui verrouillent le compte (disons après 3 tentatives de connexion échouées), cela ne finirait-il pas par verrouiller le compte. Une connexion est tentée, mais avec un fichier de «mauvaise clé»
alchemist.gamma
7
Soyez conscient si vous avez quelque chose comme fail2ban sur ces serveurs. Vous pourriez vous retrouver dans l'une de ces prisons ... à cause des tentatives infructueuses générées par les autres clés ...
Piccolo
254

La réponse de Randal Schwartz m'a presque aidé tout du long. J'ai un nom d'utilisateur différent sur le serveur, j'ai donc dû ajouter le mot-clé User à mon fichier:

Host           friendly-name
HostName       long.and.cumbersome.server.name
IdentityFile   ~/.ssh/private_ssh_file
User           username-on-remote-machine

Vous pouvez maintenant vous connecter en utilisant le nom convivial:

ssh friendly-name

D'autres mots clés peuvent être trouvés sur la page de manuel d'OpenSSH . REMARQUE: certains des mots clés répertoriés peuvent déjà être présents dans votre fichier / etc / ssh / ssh_config .

peron
la source
Si je ne me trompe pas, l'utilisateur que vous spécifiez habituellement directement dans l'url lors de la connexion avec user @ host
a1an
3
Je préfère également utiliser le mot-clé 'Port'. Un autre mot-clé intéressant est «StrictHostKeyChecking».
Ethan du
122

Les réponses précédentes ont correctement expliqué la façon de créer un fichier de configuration pour gérer plusieurs clés ssh. Je pense que la chose importante qui doit également être expliquée est le remplacement d'un nom d'hôte par un nom d'alias lors du clonage du référentiel .

Supposons que votre le nom d'utilisateur du compte GitHub de entreprise soit abc1234 . Et supposez que le nom d'utilisateur de votre compte GitHub personnel est jack1234

Et supposons que vous ayez créé deux clés RSA, à savoir id_rsa_company et id_rsa_personal . Donc, votre configuration fichier de ressemblera à ci-dessous:

# Company account
Host company
HostName github.com
PreferredAuthentications publickey
IdentityFile ~/.ssh/id_rsa_company

# Personal account
Host personal
HostName github.com
PreferredAuthentications publickey
IdentityFile ~/.ssh/id_rsa_personal

Maintenant, lorsque vous clonez le référentiel (nommé démo) du compte GitHub de l'entreprise, l'URL du référentiel sera quelque chose comme:

Repo URL: [email protected]:abc1234/demo.git

Maintenant, en faisant cela git clone, vous devez modifier l'URL du référentiel ci-dessus comme:

git@company:abc1234/demo.git

Remarquez comment github.com est maintenant remplacé par l'alias "entreprise" comme nous l'avons défini dans le fichier de configuration.

De même, vous devez modifier l'URL de clonage du référentiel dans le compte personnel en fonction de l'alias fourni dans le fichier de configuration.

oubli
la source
10
J'aimerais pouvoir voter plus d'une fois sur cette réponse ... c'est la bonne façon d'aborder le problème, et c'est plus sûr et plus rapide que les autres options. Plus évolutif aussi (permet de définir différentes clés pour le même nom d'hôte)
guyarad
4
Ne perdez plus de temps, c'est LA réponse. Merci beaucoup.
Luis Milanese
2
J'aimerais vraiment avoir trouvé cette réponse plus tôt ... mais mieux vaut tard que jamais, merci beaucoup!
Hildy
2
Grande explication! Fonctionne parfaitement pour moi. Et si vous avez oublié de cloner le dépôt avec l'alias, vous pouvez souvent modifier l'URL d'origine d'origine par la suite.
tkahn
1
ne payez que l'attention car le fichier de configuration doit être (chmod 600)
Christiano Matos
106
ssh-add ~/.ssh/xxx_id_rsa

Assurez-vous de le tester avant d'ajouter avec:

ssh -i ~/.ssh/xxx_id_rsa [email protected]

Si vous rencontrez des problèmes avec des erreurs, il peut parfois être utile de modifier la sécurité du fichier:

chmod 0600 ~/.ssh/xxx_id_rsa
user420807
la source
4
C'est à mon avis la solution la plus succincte et la plus élégante. A fonctionné comme un charme!
artur
@Bobo pouvez-vous le mettre dans votre bashrc ou bash_profile (ou quel est l'équivalent mac)?
T0xicCode
6
+1 pour chmod 0600 - des problèmes d'autorisations m'empêchaient de me connecter
amacy
Fonctionné comme un charme pour moi (et n'oubliez pas 0600 perms).
Dmytro Uhnichenko
1
Je suis venu d'ubuntu sur mac et c'était exactement ce dont j'avais besoin.
hariom
42
  1. Générez une clé SSH:

    $ ssh-keygen -t rsa -C <[email protected]>
    
  2. Générez une autre clé SSH :

    $ ssh-keygen -t rsa -f ~/.ssh/accountB -C <[email protected]>
    

    Maintenant, deux clés publiques ( id_rsa.pub , accountB.pub ) devrait être existe dans le ~/.ssh/répertoire.

    $ ls -l ~/.ssh     # see the files of '~/.ssh/' directory
    
  3. Créez un fichier de configuration ~/.ssh/configavec le contenu suivant:

    $ nano ~/.ssh/config
    
    Host bitbucket.org
        User git
        Hostname bitbucket.org
        PreferredAuthentications publickey
        IdentityFile ~/.ssh/id_rsa
    
    Host bitbucket-accountB
        User git
        Hostname bitbucket.org
        PreferredAuthentications publickey
        IdentitiesOnly yes
        IdentityFile ~/.ssh/accountB
    
  4. Cloner à partir du defaultcompte.

    $ git clone [email protected]:username/project.git
    
  5. Clonez depuis le accountBcompte.

    $ git clone git@bitbucket-accountB:username/project.git
    

Voir plus ici

Sajib Khan
la source
24

Je serais d'accord avec Tuomas sur l'utilisation de ssh-agent. Je voulais également ajouter une deuxième clé privée pour le travail et ce tutoriel a fonctionné comme un charme pour moi.

Les étapes sont les suivantes:

  1. $ ssh-agent bash
  2. $ ssh-add /path.to/private/key par exemple ssh-add ~/.ssh/id_rsa
  3. Vérifier par $ ssh-add -l
  4. Testez-le avec $ssh -v <host url>par exemplessh -v [email protected]
Wahib Ul Haq
la source
4
Ayant utilisé ssh-agentpendant des années, je suis récemment passé à l'utilisation de Gnome gnome-keyringdans mon i3wm. La raison est simple: le gestionnaire de trousseaux de clés de Gnome gère automatiquement l'ajout et la suppression de clés ssh sans que je m'en souvienne ssh-add. En plus de me fournir un seul mot de passe pour les déverrouiller (et un timeout à une heure précise, pour des raisons de sécurité). À chacun ses goûts. Depuis que j'utilise les paramètres gnome sur Arch, c'était plug n play avec ma configuration. Si vous êtes anti-gnome, ignorez ce commentaire.
eduncan911
@ eduncan911, je suis d'accord que gnome-keyring peut être utile, mais il ne gère pas vraiment les clés ed25519, donc pour moi c'est un non-starter. Mise à jour: je vois sur wiki.archlinux.org/index.php/GNOME/… qu'il utilise maintenant l'agent ssh du système, donc ce n'est plus un problème.
Brian Minton
15

J'avais rencontré ce problème il y a quelque temps, quand j'avais deux comptes Bitbucket et que je voulais avoir à stocker des clés SSH distinctes pour les deux. C'est ce qui a fonctionné pour moi.

J'ai créé deux configurations ssh distinctes comme suit.

Host personal.bitbucket.org
    HostName bitbucket.org
    User git
    IdentityFile /Users/username/.ssh/personal
Host work.bitbucket.org
    HostName bitbucket.org
    User git
    IdentityFile /Users/username/.ssh/work

Maintenant, quand j'ai dû cloner un référentiel de mon compte professionnel - la commande était la suivante.

git clone [email protected]:teamname/project.git

J'ai dû modifier cette commande pour:

git clone git@**work**.bitbucket.org:teamname/project.git

De même, la commande de clonage de mon compte personnel a dû être modifiée pour

git clone git @ personal .bitbucket.org: nom / personalproject.git

Reportez - vous à ce lien pour plus d'informations.

Ananth Pai
la source
11

Utilisez ssh-agent pour vos clés.

Tuomas Pelkonen
la source
Peux-tu élaborer?
Peter Mortensen Il y a
11

Maintenant, avec la version récente de Git, nous pouvons spécifier sshCommand dans le fichier de configuration Git spécifique au référentiel:

  [core]
      repositoryformatversion = 0
      filemode = true
      bare = false
      logallrefupdates = true
      sshCommand = ssh -i ~/.ssh/id_rsa_user
   [remote "origin"]
      url = [email protected]:user/repo.git
      fetch = +refs/heads/*:refs/remotes/origin/*
Naga Kiran
la source
1

Vous pouvez créer un fichier de configuration nommé configdans votre ~/.sshdossier. Il peut contenir:

Host aws
    HostName *yourip*
    User *youruser*
    IdentityFile *idFile*

Cela vous permettra de vous connecter à des machines comme celle-ci

 ssh aws
Andrew Crowley
la source
Quelle forme prend idFile? Un chemin absolu. Pouvez-vous donner un exemple
Peter Mortensen Il y a
1

IMPORTANT: vous devez démarrer ssh-agent

Vous devez démarrer ssh-agent (s'il ne fonctionne pas déjà) avant d'utiliser ssh-add comme suit:

eval `ssh-agent -s` # start the agent

ssh-add id_rsa_2 # Where id_rsa_2 is your new private key file

Notez que la commande eval démarre l'agent sur Git Bash sous Windows. D'autres environnements peuvent utiliser une variante pour démarrer l'agent SSH.

danday74
la source
1

Sur Ubuntu 18.04 (Bionic Beaver), il n'y a rien à faire.

Après avoir créé une deuxième clé SSH avec succès, le système essaiera de trouver une clé SSH correspondante pour chaque connexion.

Juste pour être clair, vous pouvez créer une nouvelle clé avec ces commandes:

# Generate key make sure you give it a new name (id_rsa_server2)
ssh-keygen

# Make sure ssh agent is running
eval `ssh-agent`

# Add the new key
ssh-add ~/.ssh/id_rsa_server2

# Get the public key to add it to a remote system for authentication
cat ~/.ssh/id_rsa_server2.pub
GiorgosK
la source
1

Plusieurs paires de clés sur GitHub

1.0 Fichier de configuration SSH

1.1 Créer ~ / .ssh / config

1.2 chmod 600 ~ / .ssh / config ( doit )

1.3 Saisissez les informations suivantes dans le fichier:

Pizza hôte

HostName github.com

PreferredAuthentications publickey # facultatif

IdentityFile ~ / .ssh / privatekey1

Cas A: nouveau clone de Git

Utilisez cette commande pour cloner Git:

$ git clone git@pizza:yourgitusername/pizzahut_repo.git

Remarque: Si vous souhaitez modifier le nom d'hôte «pizza» de .ssh / config à l'avenir, accédez au dossier cloné Git, modifiez la ligne d'URL du fichier .git / config (voir le cas B)

Cas B: Vous avez déjà un dossier de clonage Git

2.1 Accédez au dossier cloné, puis accédez au dossier .git

2.2 Modifier le fichier de configuration

2.3 Mettez à jour l'URL de * ancien vers nouveau :

(Old) URL = [email protected]:yourgitusername/pizzahut_repo.git

(New) URL = git@pizza:yourgitusername/pizzahut_repo.git

Chris
la source
1

Pour moi, la seule solution de travail était d'ajouter simplement ceci dans le fichier ~/.ssh/config:

Host *
  IdentityFile ~/.ssh/your_ssh_key
  IdentityFile ~/.ssh/your_ssh_key2
  IdentityFile ~/.ssh/your_ssh_key3
  AddKeysToAgent yes

your_ssh_keyest sans aucune extension. Ne pas utiliser .pub.

amdev
la source
0

Sur CentOS 6.5 exécutant OpenSSH_5.3p1 et OpenSSL 1.0.1e-fips, j'ai résolu le problème en renommant mes fichiers de clé afin qu'aucun d'entre eux n'ait le nom par défaut.

Mon répertoire .ssh contient id_rsa_foo et id_rsa_bar, mais pas id_rsa, etc.

Chris Owens
la source
Et comment les clés s'utilisent-elles? Y a-t-il une détection automatique?
robsch
Voir la réponse de Randal Schwartz pour un moyen de sélectionner la bonne clé pour un hôte donné stackoverflow.com/questions/2419566/…
Chris Owens
Oui, cela le rend plus explicite. Même l'utilisation de l' -ioption peut entraîner quelque chose comme no such identity: /home/embo/.ssh/id_rsa: No such file or directory.
Peter Mortensen Il y a
0

Comme mentionné sur une page de blog Atlassian , générez un fichier de configuration dans le dossier .ssh , comprenant le texte suivant:

#user1 account
 Host bitbucket.org-user1
     HostName bitbucket.org
     User git
     IdentityFile ~/.ssh/user1
     IdentitiesOnly yes

 #user2 account
 Host bitbucket.org-user2
     HostName bitbucket.org
     User git
     IdentityFile ~/.ssh/user2
     IdentitiesOnly yes

Ensuite, vous pouvez simplement commander avec le domaine suffixe et dans les projets, vous pouvez configurer les noms des auteurs, etc. localement.

dgbt
la source
0

Voici la solution que j'ai utilisée inspirée de la réponse de sajib-khan . La configuration par défaut n'est pas définie; c'est mon compte personnel sur GitLab et l'autre spécifié est mon compte d'entreprise. Voici ce que j'ai fait:

Générez la clé SSH

ssh-keygen -t rsa -f ~/.ssh/company -C "[email protected]"

Modifier la configuration SSH

nano ~/.ssh/config
    Host company.gitlab.com
    HostName gitlab.com
    PreferredAuthentications publickey
    IdentityFile ~/.ssh/company

Supprimer la ou les clés SSH mises en cache

ssh-add -D

Essaye-le!

ssh -T [email protected]

Bienvenue sur GitLab, @ hugo.sohm!

ssh -T [email protected]

Bienvenue sur GitLab, @HugoSohm!

Utilise le!

Compte d'entreprise

git clone [email protected]:group/project.git

Compte personnel / par défaut

git clone [email protected]:username/project.git

Voici la source que j'ai utilisée.

Hugo S
la source
0

J'adore l'approche pour définir ce qui suit dans le fichier ~ / .ssh / config:

# Configuration for GitHub to support multiple GitHub  keys
Host  github.com
  HostName github.com
  User git

# UseKeychain adds each keys passphrase to the keychain so you
# don't have to enter the passphrase each time.
  UseKeychain yes

# AddKeysToAgent would add the key to the agent whenever it is
# used, which might lead to debugging confusion since then
# sometimes the one repository works and sometimes the
# other depending on which key is used first.
#  AddKeysToAgent yes

# I only use my private id file so all private
# repositories don't need the environment variable
# `GIT_SSH_COMMAND="ssh -i ~/.ssh/id_rsa"` to be set.
  IdentityFile ~/.ssh/id_rsa

Ensuite, dans votre référentiel, vous pouvez créer un .envfichier qui contient la sshcommande à utiliser:

GIT_SSH_COMMAND="ssh -i ~/.ssh/your_ssh_key"

Si vous utilisez ensuite par exemple dotenv, la variable d'environnement d'environnement est exportée automatiquement et whoop whoop, vous pouvez spécifier la clé souhaitée par projet / répertoire. La phrase secrète n'est demandée qu'une seule fois car elle est ajoutée au trousseau.

Cette solution fonctionne parfaitement avec Git et est conçue pour fonctionner sur un Mac (en raison de UseKeychain).

blackjacx
la source
-1

Vous pouvez essayer ce package sshmulti npm pour gérer plusieurs clés SSH.

Anto Khan
la source
Je recommande fortement de ne pas utiliser npm pour quelque chose comme ça. Il y avait une cascade de dépendances, qui, après une brève inspection, incluent une gamme de développeurs de loups solitaires, des packages vieux de plusieurs années. La page sshmulti npm elle-même déclare qu'elle n'a pas été testée.
Jack Wasey