SSH私钥登陆方案配置及VSCode支持

在主机(Linux)和客户端(Windows)开启并配置好ssh后,在客户端登陆需要主机账户的密码,如果使用的是VSCode话打开文件夹还要再输入一遍,导致实际使用需要输入两次密码,十分不方便。

如果使用的是公钥认证而不是密码认证的话,能通过存在客户端上的私钥文件直接"免登陆"访问主机,是一个一本万利的操作。

下面简单记录一下开启公钥认证的流程及VSCode配置。

1. 生成密钥对

PubkeyAuthentication用的是基于公钥密码学的数字签名方案,不同于加密可以一个公钥对应N个私钥,作为签名验证使用的话公钥和私钥要求是一一对应的。

具体来说,使用私钥进行签名,公钥进行验证。对于SSH登陆的场景,主机需要验证客户端的身份,因此公钥存储在服务器端,私钥存放在主机端。

在windows下运行下面的指令生成密钥对。ed25519比RSA更加现代和安全。

bash 复制代码
ssh-keygen -t ed25519 -f id_ed25519

执行完后当前目录下就会产生id_ed25519和id_ed25519.pub。

2. 将公钥放到服务器端

a. 查看公钥内容

在windows下运行下面的指令获得公钥内容,因为安全因素不建议将公钥存储到服务器端。

bash 复制代码
type id_ed25519.pub

b. 添加公钥至服务器端

在Linux端 /user/.ssh/authorized_keys 下将复制好的公钥黏贴进去。

c. 服务器端允许公钥验证登陆

sshd是验证端,因此修改 /etc/ssh/sshd_config 配置文件,将PubkeyAuthentication的值改到yes。

改完配置文件后记得重启sshd服务:

bash 复制代码
service sshd restart

3. 验证

在客户端验证一下是否能够通过公钥认证进行登陆。-vvv打开调试模式可以看到具体的认证信息。

bash 复制代码
ssh -vvv -i path_to\id_ed25519 -p xxxx user@server_ip

如果正常的话就说明配置完成,可以进一步进行ssh客户端的配置了。

4. VSCode配置

在VSCode的ssh配置文件中加上IdentityFile字段,存储私钥的位置。

这时再从VsCode重新连接就不需要手动输入密码了。

相关推荐
威迪斯特4 小时前
CentOS图形化操作界面:理论解析与实践指南
linux·运维·centos·组件·图形化·桌面·xserver
一方热衷.4 小时前
在线安装对应版本NVIDIA驱动
linux·运维·服务器
独自归家的兔4 小时前
ubuntu系统安装dbswitch教程 - 备份本地数据到远程服务器
linux·运维·ubuntu
ONE_SIX_MIX5 小时前
ubuntu 24.04 用rdp连接,桌面黑屏问题,解决
linux·运维·ubuntu
龙飞055 小时前
Systemd -systemctl - journalctl 速查表:服务管理 + 日志排障
linux·运维·前端·chrome·systemctl·journalctl
春日见5 小时前
如何创建一个PR
运维·开发语言·windows·git·docker·容器
DARLING Zero two♡5 小时前
告别 Docker 命令行!Portainer+cpolar 让容器管理从局域网走向公网
运维·docker·容器
消失的旧时光-19435 小时前
Linux 编辑器入门:nano 与 vim 的区别与选择指南
linux·运维·服务器
斯普信专业组5 小时前
构建基于MCP的MySQL智能运维平台:从开源服务端到交互式AI助手
运维·mysql·开源·mcp
liu****6 小时前
2.深入浅出理解虚拟化与容器化(含Docker实操全解析)
运维·c++·docker·容器·虚拟化技术