Linux系统如何搭建SSH实现动态密码登录的配置方法?

在Linux系统中搭建SSH动态密码登录,通常指通过集成动态密码(如一次性密码OTP)增强SSH登录安全性,防止密码泄露或暴力破解,以下是详细搭建步骤,以Google Authenticator(基于TOTP算法)为例,实现静态密码+动态密码的双因素认证(2FA)。

linux如何搭建 ssh 动态密码登录

安装必要软件

首先需安装Google Authenticator的PAM(Pluggable Authentication Modules)模块,该模块负责动态密码的验证逻辑,不同Linux发行版的安装命令不同:

发行版 安装命令
Ubuntu/Debian sudo apt update && sudo apt install libpam-google-authenticator
CentOS/RHEL sudo yum install google-authenticatorsudo dnf install google-authenticator

安装完成后,确保系统已安装SSH服务(sudo apt install openssh-serversudo yum install openssh-server),并启动SSH服务(sudo systemctl start sshd,并设置开机自启:sudo systemctl enable sshd)。

为用户配置动态密码

以用户exampleuser为例,执行以下操作:

  1. 切换到目标用户:sudo su - exampleuser
  2. 运行google-authenticator命令,按提示配置
    • 命令会生成一个密钥(Secret Key),并显示二维码(可通过Google Authenticator、FreeOTP等APP扫描绑定)。
    • 提示是否“启用基于时间的一次性密码(TOTP)”,选择y
    • 提示是否“防止重用已使用过的动态密码”,选择y(增强安全性)。
    • 提示是否“为每个用户设置独立的文件路径”,默认即可(通常在~/.google_authenticator)。
    • 提示是否“允许紧急访问码(Recovery Codes)”,选择y并保存8位应急码(用于丢失动态密码时登录)。

配置完成后,用户目录下会生成.google_authenticator文件,包含密钥和验证规则。

linux如何搭建 ssh 动态密码登录

配置PAM模块启用动态密码验证

PAM模块通过配置文件控制认证流程,需修改/etc/pam.d/sshd文件(SSH服务的PAM配置文件):

  1. 备份原配置:sudo cp /etc/pam.d/sshd /etc/pam.d/sshd.bak
  2. 编辑文件:sudo nano /etc/pam.d/sshd
  3. 在文件开头添加以下行(若已存在@include common-auth,需注释掉):
    auth required pam_google_authenticator.so secret=/home/exampleuser/.google_authenticator user=exampleuser
    • secret:指定动态密码密钥文件路径(需根据用户调整,如/root/.google_authenticator则用户为root)。
    • user:指定目标用户名(若需对所有用户生效,可省略user参数,但需确保每个用户都有.google_authenticator文件)。

配置SSH服务支持密码认证

确保SSH服务允许密码认证,并禁用仅密钥认证(若需保留密钥登录,可跳过此步):
编辑/etc/ssh/sshd_config文件:sudo nano /etc/ssh/sshd_config
找到以下配置并修改:

PasswordAuthentication yes  # 启用密码认证(默认可能为no,需改为yes)
ChallengeResponseAuthentication yes  # 启用挑战响应认证(PAM模块依赖此选项)
PubkeyAuthentication yes  # 保留密钥登录(可选,默认为yes)

修改后保存,重启SSH服务:sudo systemctl restart sshd

测试动态密码登录

  1. 在另一台设备上使用SSH客户端连接服务器:ssh exampleuser@服务器IP
  2. 输入静态密码(用户系统密码),提示输入动态密码时,打开手机上的Google Authenticator APP,输入当前6位动态密码。
  3. 若输入正确,则登录成功;若错误,会提示“Authentication failure”。

若应急码未配置且动态密码丢失,可使用应急码登录(输入时需在应急码前加,如#123456)。

linux如何搭建 ssh 动态密码登录

安全优化建议

  1. 禁用root直接登录:编辑/etc/ssh/sshd_config,设置PermitRootLogin no,降低风险。
  2. 限制登录尝试:安装fail2bansudo apt install fail2ban),配置规则防止暴力破解。
  3. 定期更新密钥:建议每3-6个月重新运行google-authenticator生成新密钥,并更新APP绑定。

相关问答FAQs

Q1:忘记动态密码且应急码丢失,无法登录服务器怎么办?
A1:需通过物理接触服务器或使用控制台(如VNC、IDRAC)登录,以root权限修改用户认证方式:

  1. 临时禁用PAM模块:编辑/etc/pam.d/sshd,注释掉添加的pam_google_authenticator.so行(行首加)。
  2. 重启SSH服务:sudo systemctl restart sshd
  3. 登录后重新生成动态密码密钥:sudo su - exampleuser,运行google-authenticator按提示配置。
  4. 恢复PAM模块配置,重启SSH服务。
    注意:此操作仅在紧急情况下使用,恢复后需立即重新配置动态密码。

Q2:如何为多个用户批量配置动态密码登录?
A2:可通过脚本批量生成密钥并配置PAM模块:

  1. 创建用户列表(如users.txt),每行一个用户名。
  2. 批量生成密钥:for user in $(cat users.txt); do sudo su - $user -c "google-authenticator -t -d -f -r 3 -R 30 -w 3"; done
    • 参数说明:-t启用TOTP,-d禁用重用密码,-r 3生成3个应急码,-R 30设置密钥有效期30天,-w 3允许3次登录失败。
  3. 修改PAM配置文件,添加对所有用户的动态密码验证(省略user参数,确保每个用户目录下有.google_authenticator文件)。
  4. 重启SSH服务使配置生效。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/32878.html

(0)
酷番叔酷番叔
上一篇 2025年9月30日 03:51
下一篇 2025年9月30日 04:06

相关推荐

  • memcpy和strcmp哪个更高效?

    在Linux驱动开发中,直接包含标准C库(如glibc)是不可行的,因为内核空间与用户空间存在根本性差异,以下是详细的技术解析和解决方案:为什么不能直接包含标准C库?内核空间限制Linux内核运行在特权级(Ring 0),而标准C库(如printf、malloc)依赖用户空间的系统调用(如write、brk……

    2025年7月31日
    5900
  • Linux安装MySQL后初始密码如何查看?

    通过日志文件查找初始密码(推荐)MySQL 5.7及以上版本在安装时会自动生成临时密码,并记录在日志文件中,操作步骤:打开日志文件Ubuntu/Debian系统: sudo cat /var/log/mysqld.log # 通用路径或sudo cat /var/log/mysql/error.log # 部分……

    2025年6月24日
    6700
  • Linux如何打开文件夹?命令行与图形界面操作方法

    在Linux系统中,打开文件夹是日常操作的基础,根据用户习惯和场景不同,可通过图形界面(GUI)或命令行(CLI)两种方式实现,图形界面操作直观便捷,适合新手;命令行则更高效灵活,适合高级用户或自动化场景,以下将详细介绍不同方法及注意事项,图形界面(GUI)打开文件夹的方法Linux的图形界面操作依赖于桌面环境……

    2025年8月27日
    5300
  • Linux系统如何正确退出登陆?

    在Linux系统中,退出登录是日常操作中不可或缺的一环,它不仅关系到用户会话的正常终止,还涉及系统资源的释放、安全性的保障以及后续用户的使用体验,不同的登录场景(如命令行登录、远程SSH登录、图形界面登录)对应着不同的退出方式,理解这些方法的原理和适用场景,能够帮助用户更高效、安全地管理系统会话,本文将详细解析……

    2025年10月3日
    2800
  • Linux如何创建脚本文件及打开方法?

    在Linux系统中,脚本文件是实现自动化任务的核心工具,通过编写脚本可以批量执行命令、简化重复操作,创建和打开脚本文件是Linux用户的基础技能,本文将详细介绍具体操作步骤、常用方法及注意事项,创建脚本文件的方法Linux中创建脚本文件主要通过命令行或图形界面完成,以下是常用命令行方法:使用touch命令创建空……

    2025年9月19日
    4100

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信