Tools for SSH key management

Time-saving shortcuts for a commonly used open source tool.
187 readers like this.

I use SSH constantly. Every day I find myself logged in to multiple servers and Pis (both in the same room as me and over the internet). I have many devices I need access to, and different requirements for gaining access, so in addition to using various SSH/SCP command options, I have to maintain a config file with all the connection details.

Over time I’ve come up with a few time-saving tips and tools that you might find useful, too.

SSH keys

SSH keys are a way to authenticate SSH connections without using a password, either to speed up your access or as a security measure, if you turn password access off and ensure only authorized keys are permitted. To create an SSH key, run the command:

$ ssh-keygen

This will create a key-pair (a public and private key) in ~/.ssh/. Keep the private key (id_rsa) on the PC and never share it. You can share the public key ( with others or place it on other servers.


If I’m working on a Pi at home or work, I tend to leave SSH settings at their default, as I’m not concerned with security on an internal trusted network, and I usually copy my SSH key to the Pi to avoid having to authenticate with a password every time. To do this, I use the ssh-copy-id command to copy it to the Pi. This automatically adds your key to the Pi:

$ ssh-copy-id pi@

On production servers, I tend to turn off password authentication and only allow authorized SSH keys.


Another similar tool is ssh-import-id. You can use this to give yourself (or others) access to a computer or server by importing their keys from GitHub. For example, I have registered my various SSH keys with my GitHub account, so I can push to GitHub without a password. These public keys are made available, so ssh-import-id can use them to authorize me from any of my computers:

$ ssh-import-id gh:bennuttall

I can also use this to give someone else access to a server without asking them for their keys:

$ ssh-import-id gh:waveform80


I also use a tool called Storm, which helps you add SSH connections to your SSH config, so you don’t have to remember them all. You can install it with pip:

$ sudo pip3 install stormssh

Then you can add an SSH connection to your config with the following command:

$ storm add pi3 pi@

Then you can just use ssh pi3 to gain access. Similarly, scp file.txt pi3: or sshfs pi pi3:

You can also use more SSH options, such as the port number:

$ storm add pi3 pi@

You can list, search, and edit saved connections easily using Storm’s documentation. All Storm actually does is manage items in your ssh config file at ~/.ssh/config. Once you see how these are stored, you might choose to edit them manually. An example connection in config looks like this:

Host pi3
   user pi
   port 22


SSH is an important tool for system administration, from Raspberry Pi to the largest cloud infrastructures. Familiarizing yourself with key management will forever be handy. Do you have other SSH tricks to add? I would love to have you share them in the comments.

What to read next
User profile image.
Ben is a software engineer for BBC News Labs, and formerly Raspberry Pi's Community Manager. He's into Linux, Python and all things open source! Follow Ben on Twitter @ben_nuttall.


There is also sshch which I found some years ago. It's pretty nice and gives you a cli gui where you can pick your connection. It can store the password as well, but it's stored in clear text.

Very nice article
Thanks a lot

This article is about SSH key generation and nothing to with key management. Key management and private key security is a lot more complicated in enterprise.

Anyone can generate an SSH key using an OS tool available in Windows, OS X and all versions of Linux and if all else fails, there is Open SSL.

This article is about encryption, not cryptographic key management.

Creative Commons LicenseThis work is licensed under a Creative Commons Attribution-Share Alike 4.0 International License.