VS Code/Antigravity Remote SSH 连接要求输入密码?明明已经配了 SSH 密钥

问题描述

SSH config 已经配置好了密钥登录:

复制代码
Host MyServer
  HostName xx.xx.xx.xx
  User root
  Port 22
  IdentityFile "C:\Users\onefly\.ssh\id_rsa"
  ForwardAgent yes

在 Git Bash 中 ssh MyServer 可以正常免密登录,但通过 VS Code Remote SSH 连接时却弹出密码输入框。

排查过程

1. 检查服务器端

  • ~/.ssh/authorized_keys 中已有对应公钥
  • ~/.ssh 权限 700,authorized_keys 权限 600
  • sshd_configPermitRootLogin yesPubkeyAuthentication 默认启用

服务器端一切正常。

2. 发现关键线索

查看 VS Code 的 Remote SSH 日志(输出面板 → Remote - SSH),发现关键错误:

复制代码
debug1: Offering public key: C:\\Users\\ranxi\\.ssh\\id_rsa RSA SHA256:xxxxx explicit
debug1: Server accepts key: C:\\Users\\ranxi\\.ssh\\id_rsa RSA SHA256:xxxxx explicit

Bad permissions. Try removing permissions for user: MSI\CodexSandboxUsers (S-1-5-21-xxxx) on file C:/Users/ranxi/.ssh/id_rsa.
@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
@         WARNING: UNPROTECTED PRIVATE KEY FILE!          @
@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
Permissions for 'C:\\Users\\ranxi\\.ssh\\id_rsa' are too open.
This private key will be ignored.
Load key "C:\\Users\\ranxi\\.ssh\\id_rsa": bad permissions
debug1: Next authentication method: password

服务器已经接受了密钥,但客户端在签名阶段拒绝使用它,因为私钥文件权限"太开放"。

3. 根本原因

VS Code Remote SSH 使用的是 Windows 自带的 OpenSSHC:\Windows\System32\OpenSSH\ssh.exe),而不是 Git Bash 自带的 OpenSSH。

两者的区别:

Git Bash OpenSSH Windows OpenSSH
路径 C:\Program Files\Git\usr\bin\ssh.exe C:\Windows\System32\OpenSSH\ssh.exe
权限检查 使用 POSIX 模拟,较宽松 使用 Windows ACL,严格检查

Windows OpenSSH 发现私钥文件被 CodexSandboxUsers 用户组拥有继承的读取权限((I)(RX)),认为不安全,直接拒绝使用密钥,fallback 到密码认证。

解决方案

PowerShell(管理员)CMD 中执行:

powershell 复制代码
icacls C:\Users\ranxi\.ssh\id_rsa /inheritance:r /grant ranxi:F /grant SYSTEM:F /grant Administrators:F

这条命令做了三件事:

  1. /inheritance:r --- 移除继承的权限(去掉 CodexSandboxUsers 等继承来的 ACL)
  2. /grant onefly:F --- 给当前用户完全控制权
  3. /grant SYSTEM:F /grant Administrators:F --- 保留系统和管理员权限

执行后验证:

powershell 复制代码
icacls C:\Users\ranxi\.ssh\id_rsa

输出应该只有:

复制代码
C:\Users\ranxi\.ssh\id_rsa BUILTIN\Administrators:(F)
                           NT AUTHORITY\SYSTEM:(F)
                           MSI\ranxi:(F)

没有 CodexSandboxUsers 了,重新连接 VS Code Remote SSH 即可免密登录。

总结

  • 现象:Git Bash SSH 正常,VS Code Remote SSH 要密码
  • 原因:两者用的是不同的 SSH 客户端,Windows OpenSSH 对私钥文件权限检查更严格
  • 修复:移除私钥文件上多余用户组的继承权限
相关推荐
薛定谔的猫3694 天前
深入浅出 MCP (Model Context Protocol):开启 AI Agent 的标准化连接时代
ai·llm·agent·技术分享·mcp
ApacheSeaTunnel13 天前
Apache SeaTunnel Zeta 为什么能做到“又快又稳”?
大数据·开源·数据集成·seatunnel·技术分享·数据同步
数字新视界18 天前
DCIM管理系统是什么?它在智能化数据中心管理中有哪些重要功能?
数据中心·技术分享·机房管理·动环监控·新人首发
小虎哥-技术博客20 天前
宝塔面板计划任务设置教程
技术分享
eyoucms22 天前
防伪码查询系统源码二次开发指南:5步实现定制化功能
技术分享
带娃的IT创业者23 天前
NCT 是什么——让 AI 拥有意识的尝试
人工智能·深度学习·神经网络·科普·技术分享·ai架构·nct
带娃的IT创业者23 天前
全局工作空间——大脑的“黑板“
人工智能·深度学习·神经网络·科普·技术分享·ai架构·全局工作空间
ApacheSeaTunnel1 个月前
祝贺 Apache SeaTunnel PMC 新成员张圣航!
大数据·开源·数据集成·seatunnel·技术分享
博客zhu虎康1 个月前
我的创作纪念日——五载创作路,以技术赴热爱
前端·经验分享·csdn·技术分享·我的创作纪念日
孤飞2 个月前
Git 小妙招:本地忽略文件变更,不影响远程仓库
技术分享