【Linux】VSCode Remote-SSH 无法连接并反复要求输入密码问题详解

【Linux】VSCode Remote-SSH 无法连接并反复要求输入密码问题详解

文章目录

Visual Studio Code(简称 VS Code)作为一款广受欢迎的轻量级编辑器,其 Remote-SSH 插件为开发者带来了便捷的远程开发体验。然而,在使用 Remote-SSH 插件连接远程服务器的过程中,很多用户会遇到输入密码后仍无法连接的问题,甚至被持续提示输入密码。本文将围绕这一常见问题展开详细分析,并结合真实解决过程,帮助开发者顺利排查与解决相关故障。

一、问题现象描述

1. 典型表现

当使用 VS Code 的 Remote-SSH 功能连接远程服务器时:

  • 成功输入密码后,VS Code 并未正常连接服务器;
  • 系统反复弹出“请输入 SSH 密码”的提示窗口;
  • 即使密码无误,连接始终无法建立;
  • Terminal 中可能看到 "Retrying after error: Connection refused""Permission denied" 之类的提示;
  • 有时会自动执行安装 VS Code Server 的命令,但无反应或失败。

2. 常见的误区尝试

  • 反复重启 VS Code;
  • 更换网络环境;
  • 再三确认 SSH 密码是否输入正确;
  • ~/.ssh/config 中重新配置主机信息;
  • 尝试通过命令行使用 ssh user@host 连接远程主机,结果显示一切正常。

但令人困惑的是,即便通过终端可以正常使用 SSH 登录,Remote-SSH 插件却依然连接失败。

二、原因分析

该问题的根本原因通常并不在于 SSH 配置错误或网络异常,而是出现在 VS Code 在服务器上部署的 vscode-server 出现异常或损坏

Remote-SSH 插件在首次连接服务器时,会自动将一个小型的 vscode-server 程序上传至远程主机的 ~/.vscode-server 目录中,并通过该程序建立编辑器与远程主机之间的通信。

当这个 vscode-server 出现以下情况时就可能导致问题:

  • 安装过程中被中断;
  • 升级 VS Code 后版本不一致;
  • .vscode-server 目录权限错误或文件损坏;
  • 残留的临时文件引起冲突;
  • 磁盘空间不足或远程主机资源紧张。

三、解决方案详解

1. 首选方式:清除服务器上的 vscode-server

可以通过清除服务器上的 .vscode-server 目录来强制 VS Code 在下次连接时重新部署该服务。操作步骤如下:

第一步:登录远程服务器(如果你有办法…)

第二步:删除 .vscode-server 目录

rm -rf ~/.vscode-server 
注意:如果使用的是 VS Code Insiders,则目录名可能为 ~/.vscode-server-insiders;也有使用的是 ~/.vscode-remote,需根据具体情况处理。

第三步:重新连接 VS Code Remote-SSH

重新在 VS Code 中打开命令面板(Ctrl + Shift + P),执行:

Remote-SSH: Connect to Host... 

选择目标主机,系统将重新部署 VS Code Server,并建立新的连接。

2. 备选方式:使用 Remote-SSH 提供的清理命令

如果你希望使用 GUI 操作,也可以执行:

Remote-SSH: Kill VS Code Server on Host... 

然后选择对应的主机。该命令会尝试远程执行清理任务,终止正在运行的 server 实例并删除缓存目录。

然而在某些场景中,该命令无法完全清理干净,此时建议回到方案一手动删除。

3. 验证连接是否恢复正常

删除后再次连接时,VS Code 应该会提示:

Installing VS Code Server on remote... 

几秒钟后如果一切顺利,你将进入远程环境,文件树、终端等功能正常显示,问题解决。

四、其他可能性排查

1. 检查 SSH 密钥方式是否启用

如果使用的是密钥认证方式(推荐),请确认以下几个方面:

  • 公钥是否已添加至远程主机的 ~/.ssh/authorized_keys
  • 私钥权限为 600,即 chmod 600 ~/.ssh/id_rsa
  • ssh-agent 正确启动并加载私钥
  • .ssh/config 文件配置是否正确,如下:
Host my-server HostName 192.168.1.100 User myuser IdentityFile ~/.ssh/id_rsa 

2. 确保服务器未被防火墙或权限阻止

有些服务器可能对特定 IP 或端口有限制。你可以在服务器端查看 /var/log/auth.log 或使用以下命令查看是否有登录记录:

sudo journalctl -u ssh

3. 更新 Remote-SSH 插件

确保你使用的是最新版 Remote-SSH 插件,有些旧版本存在稳定性问题。打开插件管理器,搜索 Remote - SSH 并点击更新。

推荐:JavaScriptreactvue

在这里插入图片描述

Read more

pyproject.toml 完全指南:Python 项目配置的现代化之路

pyproject.toml 完全指南:Python 项目配置的现代化之路

pyproject.toml 完全指南:Python 项目配置的现代化之路 前言 如果你刚接触 Python 项目开发,可能会发现很多开源项目的根目录下都有一个 pyproject.toml 文件。它是什么?为什么需要它?本文将从零开始,带你全面了解这个 Python 生态中的"配置中枢"。 一、什么是 pyproject.toml? 1.1 定义 pyproject.toml 是 Python 项目的标准化配置文件,采用 TOML (Tom’s Obvious Minimal Language) 格式编写。它在 2016 年通过 PEP 518 被引入 Python 生态。

By Ne0inhk
2026 Python+AI入门|0基础速通,吃透热门轻量化玩法

2026 Python+AI入门|0基础速通,吃透热门轻量化玩法

🎁个人主页:User_芊芊君子 🎉欢迎大家点赞👍评论📝收藏⭐文章 🔍系列专栏:AI 文章目录: * 一、2026 Python+AI入门,必抓3个热门新趋势 * 二、入门前提:不用啃硬骨头,掌握这2点就够了 * 环境搭建(10分钟搞定,Windows/Mac通用) * 三、3个实战案例 * 案例1:30行代码开发AI文本总结工具(轻量化工具,最易上手) * 案例2:大模型微调入门(Llama 3微调,2026热门) * 案例3:AI自动数据标注(图像标注,企业刚需) * 四、Python+AI入门学习流程图(2026最新,不绕路) * 五、2026新手避坑指南 * 六、总结 【前言】 大家好,我是一名深耕AI入门教学的开发者,

By Ne0inhk
现代 Python 开发:uv 安装、配置与最佳实践

现代 Python 开发:uv 安装、配置与最佳实践

目录 * 一、uv 是什么? * 二、uv 的安装 * 1. 通用安装方式(推荐) * 2. 包管理器安装(可选) * 3. 验证安装 * 三、uv 核心使用场景 * 1. 基础包安装/卸载 * 2. 虚拟环境管理 * 3. 项目依赖管理(兼容 pyproject.toml) * 4. 运行 Python 代码/脚本 * 四、进阶用法 * 总结 一、uv 是什么? uv 是由 Astral 公司开发的 Rust 编写的 Python 工具链,核心优势是极速(比 pip

By Ne0inhk
在Windows11系统上配置interl Realsense D435i深度相机+Python

在Windows11系统上配置interl Realsense D435i深度相机+Python

一、产品介绍 Intel RealSense D435i是英特尔公司推出的一款消费级深度相机,它的主要构成如下图所示。 主要包含一个RGB相机、两个红外相机以及一个红外发射器,此外还有一个IMU单元(这也就是D435i和D435的区别,i就表示imu)。简单来说它的深度成像原理是主动立体红外成像,不是传统意义上理解的双目RGB相机成像,这点需要注意一下。 有了深度图(3D点云)和对应的RGB影像,因此也就很容易获得RGB-D点云了。因此从输出的角度而言,D435i可以看做是一个RGB-D传感器相机。后续可以搭配ORB-SLAM中RGB-D的模式进行使用。当然,也可以只用单目RGB影像,以单目SLAM模式运行,或者单目结合IMU,以Mono-Initial模式运行。唯一不能运行的是双目RGB模式(因为两个红外相机是单通道的)。当然我们可以获取双目的红外影像,以此作为输入,进行双目SLAM,结果也是类似的。因此可以看出,D435i是一个比较“全能”的传感器,从单目、单目+IMU、双目、双目+IMU、RGB-D都可以使用。 对于它的一些技术上的参数,这里也简单列举一下: * 深度技

By Ne0inhk