0

0

解决VS Code远程SSH连接时的权限和密钥问题

P粉986688829

P粉986688829

发布时间:2026-01-07 16:59:21

|

572人浏览过

|

来源于php中文网

原创

vs code通过remote-ssh连接失败主因是权限与密钥配置不当:本地私钥(600)、config(600)、远程authorized_keys(600)及.ssh目录(700)权限须合规;需确认ssh配置路径一致、禁用ssh-agent依赖、远程sshd启用pubkeyauthentication,并注意ed25519密钥在旧服务器上的兼容性问题。

解决vs code远程ssh连接时的权限和密钥问题

VS Code 通过 Remote-SSH 扩展连接远程服务器时,最常见的失败原因就是权限配置不当或 SSH 密钥不被正确识别。核心问题通常不是“连不上”,而是“连上了但被拒绝”——比如提示 Permission denied (publickey)Failed to authenticate。关键在于本地 SSH 配置、密钥格式、远程用户家目录及 .ssh 权限三者必须同时合规。

检查并修复本地 SSH 密钥权限

OpenSSH 对私钥文件权限极其敏感:私钥(如 id_rsa)不能被组或其他人读写,否则直接忽略。Windows(WSL 或 Git Bash)和 macOS/Linux 都适用此规则。

  • 运行 ls -l ~/.ssh/id_rsa(Linux/macOS)或 ls -l $HOME/.ssh/id_rsa(WSL),确认输出中权限为 -rw-------(即 600)
  • 如果不是,执行:chmod 600 ~/.ssh/id_rsa
  • 同理,确保 ~/.ssh/config 权限为 600,~/.ssh/authorized_keys(远程端)为 600,~/.ssh 目录为 700
  • 避免用记事本或 VS Code 直接编辑私钥文件——可能引入 BOM 或换行符错误;推荐用 vimcode --disable-extensions 编辑

确认 VS Code 使用的是正确的 SSH 配置路径

Remote-SSH 默认读取系统 SSH 配置(~/.ssh/config),但如果你在 Windows 上用 OpenSSH for Windows,或自定义了 SSH_CONFIG_FILE 环境变量,VS Code 可能找不到配置。

SekoTalk
SekoTalk

商汤科技推出的AI对口型视频创作工具

下载
  • 在 VS Code 命令面板(Ctrl+Shift+P)中运行 Remote-SSH: Open Configuration File...,选择对应平台的 config 路径,确保它和终端里 ssh -F 指定的路径一致
  • ~/.ssh/config 中明确指定密钥路径:
    Host myserver<br>
      HostName 192.168.1.100<br>
      User alice<br>
      IdentityFile ~/.ssh/my_private_key
  • 避免使用 ssh-add 后依赖 agent —— Remote-SSH 默认不继承终端的 ssh-agent,除非你启用了 "remote.ssh.enableAgentForwarding": true 并确认 agent 正常运行

验证远程端 sshd 配置与用户环境

即使密钥和权限都对,远程服务器的 SSH 守护进程也可能禁用公钥认证,或用户 shell、家目录权限异常导致认证跳过。

  • 登录服务器终端,检查 /etc/ssh/sshd_config 是否含:
    PubkeyAuthentication yes<br>
    AuthorizedKeysFile .ssh/authorized_keys

    修改后需重启服务:sudo systemctl restart sshd
  • 确认远程用户家目录属主是该用户,且不可被组/其他写:chmod 755 ~(不是 777!)
  • 检查 ~/.ssh/authorized_keys 内容是否完整、无多余空格或换行;每行一个公钥,开头是 ssh-rsassh-ed25519,结尾是邮箱或注释
  • 临时用命令行测试:ssh -v -F ~/.ssh/config myserver,观察日志中是否尝试 publickey、是否报 Authentication refusedno mutual signature algorithm(后者常见于旧版 OpenSSH 与新密钥类型不兼容)

处理常见密钥类型与兼容性问题

新版 ssh-keygen 默认生成 Ed25519 密钥,但部分老旧服务器(如 CentOS 7 默认 OpenSSH 6.6)不支持。若遇到 no mutual signature algorithm,需降级生成 RSA 密钥。

  • 生成兼容性更强的 RSA 密钥:ssh-keygen -t rsa -b 4096 -f ~/.ssh/id_rsa_compatible
  • 将公钥追加到远程:ssh-copy-id -i ~/.ssh/id_rsa_compatible.pub user@host(若失败,手动复制内容到 ~/.ssh/authorized_keys
  • ~/.ssh/config 中绑定该密钥:IdentityFile ~/.ssh/id_rsa_compatible
  • Windows 用户注意:PuTTYgen 生成的密钥默认是 PPK 格式,VS Code 不支持;需用 PuTTYgen → Conversions → Export OpenSSH key(无密码)再使用

基本上就这些。多数连接失败不是网络问题,而是权限链上某一处松动——从本地私钥权限、config 文件路径、远程目录结构到 sshd 配置,环环相扣。逐项核对日志输出,比反复重试更有效。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
自建git服务器
自建git服务器

git服务器是目前流行的分布式版本控制系统之一,可以让多人协同开发同一个项目。本专题为大家提供自建git服务器相关的各种文章、以及下载和课程。

978

2023.07.05

git和svn的区别
git和svn的区别

git和svn的区别:1、定义不同;2、模型类型不同;3、存储单元不同;4、是否拥有全局版本号;5、内容完整性不同;6、版本库不同;7、克隆目录速度不同;8、分支不同。php中文网为大家带来了git和svn的相关知识、以及相关文章等内容。

578

2023.07.06

git撤销提交的commit
git撤销提交的commit

Git是一个强大的版本控制系统,它提供了很多功能帮助开发人员有效地管理和控制代码的变更,本专题为大家提供git 撤销提交的commit相关的各种文章内容,供大家免费下载体验。

275

2023.07.24

git提交错误怎么撤回
git提交错误怎么撤回

git提交错误撤回的方法:git reset head^:撤回最后一次提交,恢复到提交前状态。git revert head:创建新提交,内容与之前提交相反。git reset :使用提交的 sha-1 哈希撤回指定提交。交互式舞台区:标记要撤回的特定更改,然后提交,排除已撤回更改。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

567

2024.04.09

git怎么对比两个版本的文件内容
git怎么对比两个版本的文件内容

要对比两个版本的 git 文件,请使用 git diff 命令:git diff 比较工作树和暂存区之间的差异。git diff 比较两个提交或标签之间的差异。git diff 输出显示差异块,其中 + 表示添加的行,- 表示删除的行, 表示修改的行。可使用 gitkraken、meld、beyond compare 等可视化工具更直观地查看差异。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

532

2024.04.09

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

1431

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1164

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

834

2023.08.01

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

44

2026.03.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
2022大前端凭啥拿高薪?
2022大前端凭啥拿高薪?

共6课时 | 2.1万人学习

PHP代码整洁之道
PHP代码整洁之道

共7课时 | 8万人学习

http状态码大全
http状态码大全

共47课时 | 109.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号