Pour lancer ssh-agent au lancement de la session, on va créer un service systemd pour l'utilisateur :
[Unit] Description=SSH key agent [Service] Type=forking Environment=SSH_AUTH_SOCK=%t/ssh-agent.socket ExecStart=/usr/bin/ssh-agent -a $SSH_AUTH_SOCK # Workaround to prevent gnome-keyring to force apps to use their ssh-agent ExecStartPost=/usr/bin/bash -c "/usr/bin/systemctl --user set-environment SSH_AUTH_SOCK=$SSH_AUTH_SOCK GSM_SKIP_SSH_AGENT_WORKAROUND=1" [Install] WantedBy=default.target
Ensuite l'active et le démarre :
# systemctl --user enable --now ssh-agent
Il faudra ajouter la variable d’environnement au lancement du terminal, en ajoutant la ligne suivante dans le fichier ~/.bashrc :
export SSH_AUTH_SOCK="$XDG_RUNTIME_DIR/ssh-agent.socket"
et pour finir, vous aurez juste a ajouter la ligne suivante au fichier ~/.ssh/config :
AddKeysToAgent yes
Et a la prochaine connexion a votre session, le mot de passe de votre clé SSH qu'une seule fois, lors de la première connexion SSH, et sera conservée jusqu'à ce que vous vous déconnectiez.