Windows 系统上配置 SSH 密钥验证,实现无密码登录
在日常工作中,使用密码登录远程云服务器往往让人感到繁琐。云服务器的密码通常较长,难以记忆,每次登录都需要反复输入,既不便捷也影响效率。此外,由于网络不稳定,密码认证连接容易中断,导致需要频繁重新输入密码。通过配置 SSH 密钥验证,不仅可以省去密码输入的烦恼,还能提高连接的稳定性和安全性。以下是详细步骤,指导您在 Windows 系统上配置 SSH 密钥验证,实现无密码登录。
步骤 1:在 Windows 系统上生成 SSH 密钥
-
打开 PowerShell 或 CMD
在 Windows 上使用 PowerShell 或 CMD 生成 SSH 密钥。可以在 “开始” 菜单中搜索 PowerShell 或 CMD 并打开。 -
生成密钥对
输入以下命令生成 SSH 密钥对:ssh-keygen -t rsa -b 4096 -C "snn_adversial"
-t rsa
:指定密钥类型为 RSA。-b 4096
:设置密钥长度为 4096 位,以增加安全性。-C "snn_adversial"
:注释信息,可用于标识密钥,如使用者名称或用途。
在命令执行后,会出现以下提示:
-
保存密钥
系统会提示输入文件的保存路径,建议按默认路径C:\Users\Leo\.ssh\id_rsa
保存,直接按回车键即可。 -
设置密码短语(可选)
系统接着会询问是否设置密码短语,添加密码短语会增加安全性,但为了自动化连接,可以直接按回车跳过。生成完成后,密钥对会保存在
C:\Users\Leo\.ssh
目录下,包括以下两个文件:id_rsa
:私钥文件,请务必妥善保管。id_rsa.pub
:公钥文件,用于在服务器上配置。
步骤 2:将公钥上传到服务器
-
查看公钥内容
在 Windows 上,查看公钥文件id_rsa.pub
的内容。通常以ssh-rsa
开头并包含一长串字符。请复制整个公钥内容,如下图所示:
-
通过密码登录到服务器
通过以下命令登录服务器(首次登录需要输入密码):ssh -p 端口号 root@i-2.gpushare.com
-
在服务器上配置公钥
登录服务器后,将公钥添加到~/.ssh/authorized_keys
文件中。-
首先,创建
.ssh
目录(若已存在则跳过):mkdir -p ~/.ssh chmod 700 ~/.ssh
-
使用文本编辑器(例如
nano
)编辑或创建authorized_keys
文件:nano ~/.ssh/authorized_keys
-
将公钥内容粘贴到
authorized_keys
文件中并保存。 -
设置
authorized_keys
的权限,确保仅用户自己可以访问:chmod 600 ~/.ssh/authorized_keys
-
步骤 3:在 Windows 上配置 SSH 客户端使用密钥连接
-
编辑 SSH
config
文件
打开C:\Users\Leo\.ssh
目录,在其中创建或编辑config
文件(无文件后缀)。在文件中添加以下内容以配置 SSH 连接:Host snn-adversialHostName i-2.gpushare.comPort 33804User rootIdentityFile C:\Users\Leo\.ssh\id_rsa
Host snn-adversial
:这是一个连接的别名。HostName
:服务器地址。Port
:服务器的端口号。User
:登录用户名。IdentityFile
:私钥的本地路径,指向刚才生成的id_rsa
文件。
-
测试连接
配置完成后,可以通过以下命令来测试 SSH 连接,无需输入密码:ssh snn-adversial
若配置正确,将直接连接到服务器。
步骤 4:可选 - 使用 SSH Agent 缓存密码短语(如果设置了密码短语)
如果生成密钥时设置了密码短语,可以使用 SSH Agent 来缓存,从而避免每次连接都输入密码短语。
-
启动 SSH Agent
在 PowerShell 或 CMD 中输入以下命令启动 SSH Agent:Start-Service ssh-agent
-
将私钥添加到 SSH Agent
使用以下命令将私钥添加到 SSH Agent:ssh-add C:\Users\Leo\.ssh\id_rsa
-
输入密码短语
添加私钥时会提示输入密码短语,SSH Agent 会缓存此短语,之后的连接无需再次输入。
验证连接
现在,可以通过以下命令验证连接:
ssh snn-adversial
如果一切配置正确,将直接连接到服务器而无需输入密码或密码短语。
通过以上步骤,您已经成功在 Windows 上配置了 SSH 密钥认证,实现无密码自动登录。配置 config
文件和 SSH Agent,可以大大提升连接的便捷性和安全性。