SSH Keys in Unix/Linux
SSH keys allow for a more secure login from one computer to another via
ssh
. The following instructions will show you how to setup an SSH key
using ssh-keygen
, ssh-copy-id
, and ssh
which should be available
on any Unix-like system you use.
Step 1 Generating an ssh public key and private key pair
In order to generate a public private key pair run the following command in a terminal:
ssh-keygen -t ed25519
This will ask you for a passphrase and then generate two files in the
.ssh
directory in your home folder: id_ed25519
and id_ed25519.pub
.
id_ed25519
is your private key and should NOT be given to anyone.
If someone else does access this file they will be able impersonate
you on any server you’ve uploaded that key to. id_ed25519.pub
is the
public key that will be added to the ~/.ssh/authorized_keys
file on
the server to allow you to login.
NOTE: USING A KEY PAIR WITHOUT A PASSPHRASE IS INSECURE AND SHOULD NOT BE DONE!
Other Key Formats
While all of the Computer Science department’s SSH servers accept newer
key formats like Ed25519
this is not universally true. Some services outside the university might
not. You may wish to consider another algorithm like
RSA or
ECDSA.
You can generate those types of keys by changing which argument you give
to ssh-keygen
’s -t
flag. For example, if you wanted to generate a
2048-bit RSA key you would do
ssh-keygen -t rsa -b 4096
Step 2 Setup the remote host to accept your public/private key pair
In order for the remote host to verify your login credentials you must
tell it to accept id_ed25519
as an authorized key. To do this run
ssh-copy-id ${username}@${hostname}
Be sure to replace ${username}
with YOUR username. You can replace
${hostname}
with the hostname of any CS lab machine (i.e. linux-01
)
currently running Linux.
This will ask for your password (not the passphrase you just set, but
you Computer Science domain credentials). Once you’ve authenticated the
contents of id_ed25519.pub
will be copied into
~/.ssh/authorized_keys
. To increase security you should make the
~/.ssh/authorized_keys
file readable and writeable by only your user.
To do this run
chmod 600 ~/.ssh/authorized_keys
In fact, you should be the only one to be able read and write to all
files under the ~/.ssh
directory.
You can accomplish all of this in one step by manually appending the
contents of ~/.ssh/id_ed25519.pub
to ~/.ssh/authorized_keys
with
cat ~/.ssh/id_ed25519.pub | ssh ${username}@${hostname} 'cat >> ~/.ssh/authorized_keys; chmod 600 ~/.ssh/authorized_keys'
Step 3 Check that everything is working
In order to verify that everthing is working you should try to login to the remote host using:
ssh ${username}@${hostname}
Be sure to replace ${username}
with YOUR username. You can replace
${hostname}
with the hostname of any CS lab machine (i.e. linux-01
)
currently running Linux.
If you entered a passphase for you key then you will see the following:
Enter passphrase for key '/home/${username}/.ssh/id_ed25519':
Enter the passphrase for your key pair and you should be logged into the remote host.
Step 4 SSH Agent
Repeatedly typing your passphrase can be a bit of a bear. In order to avoid endlessly typing in your passphrase every time you connect to a machine see the article on using SSH Agent.