Understanding and Implementing Passwordless SSH
Online privacy and security are vital considerations in our modern era. The high value of information has caused a need to implement better security practices and strategies. <!--more--> The Secure Shell Host protocol (SSH) is one of the important security protocols used to protect data in an insecure network. The cryptographic-based protocol has evolved to a passwordless alternative to increase its resilience.
What you will learn
- What is passwordless SSH?
- The working of passwordless SSH.
- Its use cases.
- Setting up passwordless SSH.
- Advantages and disadvantages of passwordless SSH.
What is passwordless SSH
The Secure Shell or Secure Socket Shell protocol (SSH) is a cryptographic-based network protocol that Yatu Ylonen wrote in 1995. The protocol is applied when establishing secure connections between two devices, i.e., a client and a server. SSH can be implemented using several authentication techniques. The two widely used techniques are public/private-key (cryptographic) based authentication and password-based authentication.
The passwordless SSH protocol uses a process where your device establishes a connection with a remote computer without the need of you keying in a password. The improved alternative eliminates the need to use complex passwords that are hard to recall. Thus, the passwordless SSH protocol protects its users from common password-based attacks.
The working of the passwordless SSH protocol
The passwordless SSH protocol utilizes an SSH client to send a cryptographic key to and from the client device. The key exchange procedure does not use a password as it uses public-key cryptography principles.
A public key is a long string of random characters generated from a private key. As its name suggests, the public key can be shared by anyone. The process of establishing a secure connection using the passwordless SSH protocol follows the following steps:
- A user sends their username and public key to a server.
- The server responds with a message encrypted using the received public key from the user.
- The user decrypts the server’s message with its private key.
- The user sends the decrypted message to the server, which ascertains if the message is valid.
- If the message matches the one on the server, the server authenticates the user and establishes a secure connection between the two devices.
- Since future connections are automated, users do not repeat the username submission process stated in the first step.
The lack of passwords is among the main reasons for preferring the passwordless SSH over its password-based alternative.
Use cases of SSH
The SSH protocol is the remote standard method for accessing and managing Linux-based servers. Many corporate organizations utilize the protocol to administer and manage their web servers.
Some of the administration functions performed on servers using the SSH protocol include:
- Sending and receiving files over SSH through the SSH file transfer protocol (SFTP).
- Accessing and performing CRUD (create, read, update and delete) functions on users’ databases.
- Installing or updating software on the servers and other third-party web applications.
- Backing up data on servers.
- Running remote CLI commands.
- Troubleshooting the servers in case of any technical failures.
Setting up passwordless SSH
It is now time to dive into setting up the passwordless protocol on Linux. Let us get started!
If you are on a Unix-based OS, like Windows, you can use SSH client software like Putty.
Step 1: Generating your SSH key pairs
We earlier mentioned that you must have a password to establish your first connection during the setup process. However, you will not need a password after this first process since your authentication key is kept in a directory named ~/.ssh.
.
After the key is created, it is stored in a file called /id_rsa.pub.
Creating your key pair will require you to use the following command:
ssh-keygen -t [algorithm] -b [keysize]
The above command allows you to specify the keygen algorithm and key size to use. If you choose to use the RSA algorithm, it should follow the below syntax:
ssh-keygen -t RSA -b 4096.
You may choose to add your email address to increase security.
ssh-keygen -t RSA -b 4096 -C "[email protected]"
Step 2: Uploading the public key to a host server
This process provides a server with what it needs to recognize your device. Thus, you can access the server remotely using your SSH authentication key. The authentication key takes the place of a password used in a password-based system. When you wish to send your authorized ID and public key to the host, use this command:
ssh-copy-id [your_username]@[remote_server_ip_address]
Step 3: Testing to ensure everything works properly
After the authorization and establishing a connection phase, you should check whether the connection works. If the connection functions as expected, you can log in to your server without the need for a password. To establish a connection using SSH, use the following command:
ssh [your_username]@[remote_server_ip_address]
Advantages of passwordless SSH
1. Improves user experience
Passwordless SSH enhances the user experience as it removes the need for users to memorize complex or lengthy passwords. According to NordPass statistics, the average internet user has at least 10 passwords. Having many passwords makes it easy for people to forget them when logging into a system. Passwordless SSH saves users time by eliminating the need to memorize passwords.
2. Resolves the issue of password theft
Passwordless SSH implies that passwords are no longer required. Thus, users who utilize the protocol do not worry about password theft or breaches. Furthermore, Passwordless SSH minimizes the risk of legal action that results from data breaches on your website or application.
3. Protection from brute-force attacks
A brute-force attack involves an attacker guessing characters to form a password. This technique is practically unattainable on cryptographic-based protocols such as passwordless SSH. Passwordless SSH uses a cryptographic key that makes brute-forcing cumbersome. The cryptographic key is created from mathematical formulas that are easy to compute in one direction but cumbersome to compute in the opposite direction. Thus, once a key is generated, it is cumbersome for an attacker to reverse engineer the generation process.
4. Helps reduce operational costs in the long run
Passwordless authentication solutions reduce overall security costs. An organization does not need to incur costs from storing passwords on authenticating servers that require maintenance and management. The protocol also frees up the IT department as they will no longer be required to redefine password policies. The IT department will also not need to monitor user activity or detect and prevent password leakages.
Disadvantages of passwordless SSH
1. Hard to protect users after device theft
The authentication keys used to implement passwordless SSH are retained in a device. After a device theft, a person can access and use your connection since they have access to your device. Some systems that implement passwordless SSH authentication use OTPs mostly sent via SMS. Thus, users have to protect their SIM cards and phones. When someone steals your device, they can intercept the OTPs and magic links that authenticate a login session, thus compromising your security.
2. Reluctant users
Not many users have embraced passwordless authentication due to security concerns. This could be due to ignorance and false assumptions surrounding the technology. To most users, the protocol looks like a method that is easy to bypass since there are no passwords involved.
3. High cost of implementation
There are free software companies that offer free implementation of passwordless SSH. But, no one wants to entrust the security of their website or app to free tools. Most suppliers who provide services related to deploying a passwordless SSH protocol to a business charge between $25 and $1000 per month to set up the protocol. The cost incurred in hiring a professional to set up the protocol drives many businesses and organizations to opt for password-based authentication because it is cheap and quick to accomplish.
4. It does not protect against malware
Some systems that use passwordless SSH authentication require OTPs. Malware such as screen readers and keyloggers can intercept OTPs and magic links, thus compromising the security of a system.
Conclusion
In this article, we understood the basic functioning of the passwordless SSH protocol. We looked at its pros and cons and the reasons why it is better than a password-based authentication system. Additionally, we gained insights on setting up the passwordless SSH protocol on your local device. You should note that the passwordless SSH protocol holds an upper advantage over its password-based alternative. Thus, its adoption in the tech world will be swift and inevitable.
I hope you enjoyed reading the article. All the best!
References
- A Look at SSH Passwordless Authentication in cyber security by Megha Thakkar
- The Pros and Cons of Passwordless Authentication in web security by Medha Mehta.
- How to Setup Passwordless SSH Login
Peer Review Contributions by: Willies Ogola