Skip to content

Manage SSH Keys

SSH Keys are a secure way to authenticate to a server. They are a pair of cryptographic keys that can be used to authenticate to an SSH server as an alternative to password-based logins. One key is private and the other is public. When you generate an SSH key pair, you will get a private key and a public key. The private key is kept on the computer you log in from, while the public key is stored on the .ssh/authorized_keys file on all the servers you want to log in to.

Generate SSH Key Pair

To generate an SSH key pair, you can use the ssh-keygen command.

ssh-keygen

After running the command, you will be prompted to enter a file in which to save the key. You can press Enter to save it in the default location (~/.ssh/id_rsa), or specify a different location. You will also be prompted to enter a passphrase to secure the private key. You can press Enter to leave it empty, or enter a passphrase.

Once the key pair is generated, you will have two files: id_rsa (private key) and id_rsa.pub (public key). The public key can be shared with others, while the private key should be kept secure.

Copy SSH Key to Server

To add your SSH key to the SSH agent, you can use the ssh-copy-id command.

ssh-copy-id user@hostname

Replace user with your username and hostname with the IP address or domain name of the server you want to copy the key to. You will be prompted to enter your password for the server. Once the key is copied, you can log in to the server without entering a password.

After that, you can log in to the server using the following command:

ssh user@hostname

Add SSH Key to Git Server

Also, you can use SSH key to authenticate git servers like GitHub, GitLab, Bitbucket, etc. by adding your public key to your account settings.

To add your SSH key to your GitHub account, you can follow these steps:

  • Copy your public key to the clipboard.
cat ~/.ssh/id_rsa.pub | xclip -selection clipboard
  • Go to your GitHub account settings.
  • Click on "SSH and GPG keys" in the left sidebar.
  • Click on "New SSH key".
  • Paste your public key into the "Key" field.
  • Click on "Add SSH key".
  • Confirm the action by entering your GitHub password.
  • You can now use SSH to authenticate to GitHub.

To make sure your SSH key is being used, you can test the connection to the server.

ssh git@github.com

Backup SSH Keys

It is important to back up your SSH keys to prevent data loss. You can copy the ~/.ssh directory to a secure location, such as an external drive or cloud storage.

cp -r ~/.ssh /path/to/backup

Make sure to keep the backup secure and up-to-date.

Restore SSH Keys

If you need to restore your SSH keys from a backup, you can copy the ~/.ssh directory back to your home directory.

mkdir ~/.ssh
cp -r /path/to/backup/.ssh/* ~/.ssh
chmod 644 ~/.ssh/id_rsa.pub
chmod 600 ~/.ssh/id_rsa

Make sure to set the correct permissions on the private key file.

SSH to Server

To SSH to a server using a specific private key, you can use the -i option.

ssh -i /path/to/private_key user@hostname

Replace /path/to/private_key with the path to your private key file, user with your username, and hostname with the IP address or domain name of the server.

Via SSH gateway

In some cases, the Server might behind a firewall or NAT, and you need to use a jump host to connect to it. You can use the -J option to specify a jump host.

ssh -J user@jump_host user@hostname

Replace user@jump_host with the username and hostname of the jump host, and user@hostname with the username and hostname of the server.

Via HTTP proxy

In some cases, you might need to connect to a server through an HTTP proxy. You can use the ProxyCommand option to specify the proxy command.

ssh -o "ProxyCommand=nc -X connect -x <proxy_host>:<proxy_port> %h %p" <user>@<host>

Replace <proxy_host> and <proxy_port> with the hostname and port of the proxy server, <user> with your username, and <host> with the IP address or domain name of the server.