Generating a SSH key and use the result to log in to your Azure Linux VM is not that hard to accomplish.
In the following article I want to go over the steps.
Oct 17, 2019 Though there are varying methods of generating SSH keys on machines using Windows, this one uses PuTTY Key Generator. 1: Generate the key. ATTENTION: The procedure and screen captures in this section reflect the latest version of PuTTY as of July 21, 2017 (0.70). If you use a different version, your interface may differ from the one pictured.
Get PuTTYgen to generate your SSH key
First we need to download another “PuTTY” tool called PuTTY Key Generator.
Just download the PuTTYgen executable and start it.
Create a new SSH key
Next you want to make sure that SSH-2 RSA is marked.
Hit “Generate” and make sure to move the mouse within the blank area of the application.
Save the key
If your key is created you can optional set a passphrase (this would prompt you for a password on a login with your key). Also you want to save the private key (we need it later for PuTTY).
In the key field, select the hole content and copy it to the clipboard.
Add the SSH key to Azure
Login to Azure, select your VM, “All Settings” and “Reset password“. Enter a username (please mind the info box above the “User name” field) and select “SSH public key“. Insert your copied key into the text box and hit “Save“.
Log in to your VM via PuTTY
When your settings are saved, open PuTTY enter your login ip / url on the start form, then select “Connection -> SSH -> Auth” and hit “Browse …“.
Now select your saved private key and hit “Open“.
If everything worked out, PuTTY will ask for a username (optional your passphrase). Enter the username from the Azure Portal and you are logged in.
hourglass_empty
3min Read
SSH keys are one of the most secure SSH authentication options. It is definitely more secure than the usual SSH password authentication. Therefore, it is highly recommended to use SSH Key authentication method for connections to your servers.
With password authentication, you can connect to your server from any location, you only need to fill in your password. However, if your password gets leaked, it is a major risk as anyone who knows your password will be able to get into the server.
SSH Key authentication only allows connections from clients whose key matches the one on the server. Basically, you generate a key pair (private key and public key). The private key is placed on your local machine and the public key is uploaded to the server. When connecting to the server, a validation of these two keys is made and if the key pair passes the validation you are allowed to connect. Of course, you can upload keys of multiple users so that you or other authorized users would be able to connect to the server from different computers.
As you can see this is a much safer connection method. In this tutorial, we will focus on Windows users who use PuTTY for connections to the server and show how to generate PuTTYSSH Keys. If you want to generate SSH Keys on Linux or Mac, see this tutorial.
What you’ll need
Before you begin this guide you’ll need the following:
- Access to your Linux server / VPS
- PuTTY and PuTTYgen installed on your computer (Download here)
Step 1 — Downloading PuTTYgen
Most of you have PuTTY installed on your computers already, however, to generate SSH Keys you also will need PuTTYgen.
- Download PuTTYgenhere
- You should be able to see this file downloaded:
No installation is required for PuTTYgen, it will run when you execute the file.
Step 2 — Generating your SSH Key pair
- Open up PuTTYgen by double clicking on the puttygen.exe file you have downloaded in Step 1.
- You should be able to see a window like this:
- Before generating your SSH Key pair, you can edit some settings, for example, key length, however, in most cases the default options will work just fine.
- Generate your SSH Key pair by clicking the Generate button.
- When the progress bar starts loading, move your mouse randomly across the area to load up the bar and generate your key pair.
- Your public SSH key will be displayed on the screen:
- For additional security it is highly recommended to think of a passphrase for your SSH key (However, you can also leave it empty):
- Save your private key to any desired location on your computer and name it anything you like.
- Save your public key to the same location on your computer and name it anything you like.
And that is it, you have generated your SSH Key pair. The private key will stay on your computer (do not provide it to anyone) while your public key needs to be uploaded to the server you wish to connect to.
Step 3 — Setting up your private key on PuTTY
In order for the server to recognize your computer when connecting from PuTTY, you need to attach the private key to PuTTY.
- Open up PuTTY.
- Navigate to Connection -> SSH -> Auth in the left sidebar.
- Browse for your private key file in the field Private key for authentication
- Select the private key file with .ppk ending and click Open.
Step 4 – Adding public key to server
Lastly, you need to upload your public key to the server:
Putty Copy Over Generated Keys
- On your local computer, open public key file (id_rsa.pub) you generated in Step 2 with any text editor and copy its contents (public key).
- Connect to your VPS using Putty. See this guide for detailed steps.
- If .ssh folder does not exist, create it together with authorized_keys file with the following command:
mkdir ~/.ssh | touch ~/.ssh/authorized_keys
- Secure SSH Key file by changing permissions:
chmod 0700 ~/.ssh; chmod 0644 ~/.ssh/authorized_keys
- Open authorized_keys file with vim text editor:
vim ~/.ssh/authorized_keys
- Press i key on your keyboard and right mouse button to paste the public key.
- Press Esc button and type in
:x
, hit Enter button. This command will save changes made to the file.
That is it, you can now use SSH keys instead of SSH password authentication to connect to your VPS.
Copy Putty Sessions
Conclusion
Putty Copy Over Generated Key West
You have learned how to generate PuTTY SSH Keys using PuTTYgen. This will make your connection to the server a lot more secure and convenient as you will not need to fill in the password each time. We recommend using this way of SSH authentication at all times and disable password authentication for good to completely secure your server. To find out how to completely disable SSH Password authentication on your server and use SSH Key authentication instead, follow this tutorial: How to disable SSH Password authentication on VPS.