如何在Ubuntu 14.04上使用Google Authenticator为SSH设置两因素身份验证(2FA)

有几种通过SSH登录服务器的方法。方法包括密码登录,基于密钥的登录和两因素身份验证。

两因素身份验证是一种更好的保护方式。万一您的计算机受到威胁,攻击者仍将需要访问码才能登录。

在本教程中,您将学习如何使用Google Authenticator和SSH在Ubuntu服务器上设置双重身份验证。

步骤1:先决条件

  • Ubuntu 14.04服务器(或更高版本)。
  • 具有sudo访问权限的非root用户。
  • 安装了Google Authenticator App的智能手机(Android或iOS)。您也可以使用Authy或任何其他支持基于TOTP的登录名的应用程序。

第2步:安装Google Authenticator库

我们需要安装适用于Ubuntu的Google Authenticator Library模块,该模块将允许服务器读取和验证代码。运行以下命令。

sudo apt-get update
sudo apt-get install libpam-google-authenticator

步骤3:为每个用户配置Google身份验证器

要配置模块,只需运行以下命令。

google-authenticator

运行命令后,将询问您某些问题。第一个问题是:

Do you want authentication tokens to be time-based (y/n)

y,您将获得一个QR码,私钥,验证码和紧急备用码。

拿出手机,然后打开Goog​​le Authenticator应用。您可以扫描QR码或添加密钥以添加新条目。完成此操作后,记下备份代码并将其保存在安全的地方。万一您的手机放错地方或损坏,您可以使用这些代码登录。

对于其余的问题,y请在系统提示时按,以更新.google_authenticator文件,y禁止多次使用同一令牌,n增加时间窗口并y启用速率限制。

您必须对计算机上的所有用户重复步骤3,否则一旦您完成本教程,他们将无法登录。

步骤4:将SSH配置为使用Google Authenticator

现在,您计算机上的所有用户都已经设置了他们的Google身份验证器应用程序,现在该配置SSH以在当前应用程序上使用此身份验证方法了。

输入以下命令以编辑sshd文件。

sudo nano /etc/pam.d/sshd

找到该行@include common-auth并将其注释掉,如下所示。

# Standard Un*x authentication.
#@include common-auth

将以下行添加到此文件的底部。

auth required pam_google_authenticator.so

Ctrl + X保存并退出。

接下来,输入以下命令来编辑sshd_config文件。

sudo nano /etc/ssh/sshd_config

找到该术语ChallengeResponseAuthentication并将其值设置为yes。还要找到该术语PasswordAuthentication,取消注释,然后将其值更改为no

# Change to no to disable tunnelled clear text passwords
PasswordAuthentication no

下一步是将以下行添加到文件的底部。

AuthenticationMethods publickey,keyboard-interactive

通过按保存并关闭文件Ctrl + X。既然我们已经将SSH服务器配置为使用Google Authenticator,现在该重启它了。

sudo service ssh restart

尝试重新登录到服务器。这次将要求您输入身份验证码。

ssh user@serverip

Authenticated with partial success.
Verification code:

输入您的应用程序生成的代码,您将成功登录。

注意

万一您丢失了手机,请使用步骤2中的备份代码。如果您丢失了备份代码,则在.google_authenticator通过Vultr控制台登录后,始终可以在用户主目录下的文件中找到它们。

结论

进行多因素身份验证可以大大提高服务器的安全性,并可以帮助阻止常见的暴力攻击。

其他版本



Leave a Comment

AI 能否應對越來越多的勒索軟件攻擊?

AI 能否應對越來越多的勒索軟件攻擊?

勒索軟件攻擊呈上升趨勢,但人工智能能否幫助應對最新的計算機病毒?AI 是答案嗎?在這裡閱讀知道是 AI 布恩還是禍根

ReactOS:這是 Windows 的未來嗎?

ReactOS:這是 Windows 的未來嗎?

ReactOS,一個開源和免費的操作系統,這裡有最新版本。它能否滿足現代 Windows 用戶的需求並打倒微軟?讓我們更多地了解這種老式但更新的操作系統體驗。

通過 WhatsApp 桌面應用程序 24*7 保持聯繫

通過 WhatsApp 桌面應用程序 24*7 保持聯繫

Whatsapp 終於為 Mac 和 Windows 用戶推出了桌面應用程序。現在您可以輕鬆地從 Windows 或 Mac 訪問 Whatsapp。適用於 Windows 8+ 和 Mac OS 10.9+

人工智能如何將流程自動化提升到新的水平?

人工智能如何將流程自動化提升到新的水平?

閱讀本文以了解人工智能如何在小型公司中變得流行,以及它如何增加使它們成長並為競爭對手提供優勢的可能性。

macOS Catalina 10.15.4 補充更新引發的問題多於解決

macOS Catalina 10.15.4 補充更新引發的問題多於解決

最近,Apple 發布了 macOS Catalina 10.15.4 補充更新以修復問題,但似乎該更新引起了更多問題,導致 mac 機器變磚。閱讀這篇文章以了解更多信息

大數據的13個商業數據提取工具

大數據的13個商業數據提取工具

大數據的13個商業數據提取工具

什麼是日誌文件系統,它是如何工作的?

什麼是日誌文件系統,它是如何工作的?

我們的計算機以稱為日誌文件系統的有組織的方式存儲所有數據。這是一種有效的方法,可以讓計算機在您點擊搜索時立即搜索和顯示文件。 https://wethegeek.com/?p=94116&preview=true

技術奇點:人類文明的遙遠未來?

技術奇點:人類文明的遙遠未來?

隨著科學的快速發展,接管了我們的大量工作,我們陷入無法解釋的奇點的風險也在增加。閱讀,奇點對我們意味著什麼。

洞察 26 種大數據分析技術:第 1 部分

洞察 26 種大數據分析技術:第 1 部分

洞察 26 種大數據分析技術:第 1 部分

2021 年人工智能對醫療保健的影響

2021 年人工智能對醫療保健的影響

過去幾十年,醫療保健領域的人工智能取得了巨大飛躍。因此,醫療保健中人工智能的未來仍在日益增長。