How to Set Up SSH to Use Two-Factor Authentication

Secure your SSH access like a pro with two-factor authentication (2FA) to protect your remote connections even more effectively.

Secure Shell (SSH), a protocol widely used for secure remote login from one computer to another, offers robust encryption to protect against unauthorized access.

However, with the increasing sophistication of cyber threats, relying solely on traditional password-based authentication can leave systems vulnerable to brute-force attacks and password theft. This is where two-factor authentication (2FA) comes into play.

It adds an extra layer of security by requiring not only a password (something you know) but also a second factor, usually something you have (like a mobile device) or something you are (like a fingerprint).

Integrating 2FA with SSH significantly reduces the risk of unauthorized access to your systems, even if a password is compromised. So let’s show you how to do it.

Step 1: Install the 2FA Authenticator App on Your Phone

To start, you must install a 2FA authenticator app on your mobile device to use two-factor authentication with SSH. This app generates time-sensitive, one-time-use codes that serve as the second factor in the authentication process.

Popular choices for such apps include Google Authenticator or Microsoft Authenticator. They are available for Android and iOS devices and can be downloaded from the respective app stores.

For this guide, we will use the Google Authenticator app. It’s important to have it preinstalled on your mobile device, as a little further down in step 3, we’ll be using it during the initial setup of 2FA with your SSH server.

Step 2: Install Google’s PAM Authenticator Module

Google Authenticator is a software-based authentication tool that implements two-factor authentication (2FA) services using the Time-Based One-Time Password (TOTP) Algorithm and HMAC-based One-time Password (HOTP) Algorithm for authenticating users of software applications.

To get your Linux system ready for this, you must install the required package called “libpam-google-authenticator” or “google-authenticator,“ depending on your distribution. But what function does this package serve?

In short, it provides a software module for Linux that integrates the Google Authenticator into the Pluggable Authentication Module (PAM) system. PAM is a framework for integrating multiple low-level authentication schemes into a high-level API, allowing for implementing various authentication methods in programs that require user verification.

Ubuntu / Debian

Ubuntu, Debian, and other distributions based on them, such as Linux Mint or Pop!_OS, can install the Google Authenticator using the apt command below:

sudo apt install libpam-google-authenticator

Rocky Linux / AlmaLinux

For enterprise Linux distributions like Rocky and Alma, Google Authenticator is available through the EPEL repository. So, you must first add it to your system (if you haven’t already) and then install the Google Authenticator itself.

sudo dnf install epel-release
sudo dnf install google-authenticator

Fedora

Fedora users can find Google Authenticator within the official distribution repositories. To install it, execute the following command:

sudo dnf install google-authenticator

Arch Linux

Google Authenticator is available in the distro’s repos for Arch and Arch-based derivatives. To install it, run:

sudo pacman -S libpam-google-authenticator

Step 3: Configure Google Authenticator

Having successfully installed Google Authenticator, we are now ready to configure it. To do so, open the terminal and execute the command shown below.

google-authenticator

From here on, you will need to answer a few questions, with the first being, “Do you want authentication tokens to be time-based?” Answer “y” to enable Time-based One-Time Passwords (TOTP).

Configure Google Authenticator on Linux

A QR code will be displayed on your terminal screen. This is where the Google Authenticator app on your mobile device comes into play. Open it and click the “+” icon in the bottom right corner.

Google Authenticator app.

You’ll encounter two options: “Scan a QR code” and “Enter a setup key.” Given that the QR code displayed in the terminal may often be too large and challenging to scan directly from your device, we will opt for the “Enter a setup key” option. Go ahead and click on it.

In the “Account” field, enter a name of your choice, for example, “my2fa.” Then, in the “Key” field on your mobile device’s Google Authenticator app, type the code from the “Your new secret key is” line from the terminal. Finally, click on the “Add” button.

Configure Google Authenticator

In response, the app will generate a 6-digit code.

Configure Google Authenticator

Enter this code in the terminal and hit “Enter.”

Configure Google Authenticator

You should receive a “Code confirmed” message. In addition, you’ll get five emergency codes that we recommend you write down and keep somewhere safe.

These codes are one-time and grant you SSH access, for example, when you don’t have your mobile device handy for code generation. Respond with “y” when asked to update the “.google_authenticator” file.

On the next question, to increase security, again, reply with “y,” confirming that you want to disable multiple uses of the same code.

Configure Google Authenticator

The following configuration option of Google Authenticator concerns the possibility of using previously generated codes if you have not been able to fit into the 30-second time frame, which is the validity of each token from the moment of its generation.

However, since this option reduces security, we strongly recommend you reply with “n.”

Configure Google Authenticator

Finally, answer with “y” to activate the rate limit, permitting up to three login attempts within a 30-second window, thus minimizing the chance for a successful brute-force attack on your SSH server.

Configure Google Authenticator

We’ve completed the Google Authenticator setup, so now it’s time to proceed with configuring the SSH server itself to allow two-factor authentication.

Step 4: Configure SSH to Use Two-Factor Authentication

Open the SSH server configuration file for editing with your preferred terminal text editor:

sudo vim /etc/ssh/sshd_config

The thing to do here is to add/change the following two configuration values:

KbdInteractiveAuthentication yes
ChallengeResponseAuthentication yes

If you find either of the two settings in the file, change their values to “yes“. If they’re not there, just add them to the file’s end like the example below, then save and exit the file.

Configure SSH to Use Two-Factor Authentication

Now, let’s break down what those two options mean:

  • KbdInteractiveAuthentication – When enabled in SSH, it allows the server to engage in the 2FA interactive process. For example, after entering your password (the first factor), the server might prompt you for a code from your 2FA app (the second factor).
  • ChallengeResponseAuthentication – When enabled, the SSH server can use challenge-response methods for authentication. This includes methods like keyboard-interactive authentication, where the user is prompted to enter information in response to a challenge. In other words, in that case, it allows the SSH server to prompt the user to enter a code generated by a 2FA app.

Lastly, restart the SSH server, and then we can move to the last step of setting up two-factor authentication for our SSH server.

sudo systemctl restart ssh

Step 5: Setting Up PAM for SSH’s Two-Factor Authentication

PAM (Pluggable Authentication Modules) plays a crucial role in SSH’s authentication process, providing a flexible and modular framework for authentication. This means that instead of SSH having its hard-coded authentication methods, it uses PAM to plug in various authentication mechanisms as needed.

So, the last step is to configure it to allow SSH 2FA. For this, we open its configuration file:

sudo vim /etc/pam.d/sshd

Then, we should add the following line at the beginning:

auth required pam_google_authenticator.soCode language: CSS (css)
Setting Up PAM for SSH's Two-Factor Authentication

Save the file, exit, and move on to the final, most exciting part.

Step 6: Testing SSH 2FA

Now, let’s check if everything is working right. To do this from a remote machine, try making an SSH connection to the server configured to use two-factor authentication.

You will be prompted for the verification code. Open the Google Authenticator app on your mobile device and type in the terminal the 6-digit code it shows. When you type, it doesn’t show up on the screen.

Next, you’ll need to enter the user’s password. Once you put in the correct one, you will get SSH access to the server.

Testing SSH 2FA

If you look at what happens under the hood, in the systemd logs, you’ll find that the login process worked fine. The two-factor authentication code from the Google Authenticator and the user’s password were successfully accepted.

Testing SSH 2FA

However, even if you type in the correct password but use the wrong code, your SSH connection to the server won’t be allowed, as the systemd logs show.

Testing SSH 2FA

Great job! You’ve successfully set up two-factor SSH authentication, making your server much safer and well-protected from unauthorized access.

Optional: Involving Key-Based Authentication in SSH 2FA

Okay, we’ve made good progress, but we can make things even better. Let’s add an SSH key to the two-factor authentication process. This adds an extra layer of security and, at the same time, avoids the less secure approach of relying on user passwords.

To achieve this, we assume you already have a generated pair of private and public keys and have passwordless SSH authentication to the server set up and running. However, if you don’t already have one, we’ve provided a guide to help you get it done quickly and simply. Now, back on the topic.

First, open the “/etc/ssh/sshd_config” file and set the “PasswordAuthentication” option to “no,” as shown in the image below.

Setting Up a Key-Based Authentication in SSH 2FA

This tells the SSH server to disable password authentication so users cannot log in using their regular username and password. Instead, they must use alternative authentication methods, like SSH key-based authentication.

Then, add the option shown below to your “sshd_config” file.

AuthenticationMethods publickey,keyboard-interactive
Setting Up a Key-Based Authentication in SSH 2FA
  • AuthenticationMethods: Specifies the authentication methods that must be successfully completed for a user to be granted access.
  • publickey: This indicates that the first authentication method is based on public key authentication.
  • keyboard-interactive: This is the second method of authentication required after the “publickey” method is successfully completed. It typically involves the user entering information in response to a prompt. In our case, this involves introducing a 2FA code generated by the Google Authenticator app.

Save the file, close it, and restart the SSH service.

sudo systemctl restart ssh

Now, open the “/etc/pam.d/sshd” file, find the line “@include common-auth,” and put a comment mark (#) before it. This stops PAM from using the user’s account password to log in.

Setting Up a Key-Based Authentication in SSH 2FA

Now try logging in again over SSH – and the magic happens! The prompt requiring you to enter a user password is gone.

Just type in the 6-digit code generated from the Google Authenticator app on your mobile device, and you’ll be logged in. The SSH key will be sent to the server automatically in the background.

Setting Up a Key-Based Authentication in SSH 2FA

Once again, however, we clarify that you need to set up passwordless authentication to the SSH server before implementing this method.

Conclusion

Setting up two-factor authentication (2FA) for SSH access is essential in enhancing the security of your remote connections. This article detailed the steps in configuring Google Authenticator, modifying SSH server settings, and setting up PAM for SSH’s 2FA.

The result is that your SSH server is now well-protected against brute-force attacks and unauthorized access attempts. Furthermore, incorporating key-based authentication into the SSH 2FA process adds a layer of security, moving beyond reliance on passwords alone.

Thanks for your time! As always, your feedback and comments are most welcome.

Bobby Borisov

Bobby Borisov

Bobby, an editor-in-chief at Linuxiac, is a Linux professional with over 20 years of experience. With a strong focus on Linux and open-source software, he has worked as a Senior Linux System Administrator, Software Developer, and DevOps Engineer for small and large multinational companies.