VSCode Remote SSH 一直转圈连不上服务器?踩坑全记录

VSCode Remote SSH 一直转圈连不上服务器?踩坑全记录

环境:Ubuntu 服务器 / VSCode Remote SSH / Miniconda


问题描述

VSCode 通过 Remote SSH 连接服务器时,一直显示"正在连接",转圈转个没完,既不报错也不成功。

奇怪的是:

  • 用 XShell 可以正常登录同一个账号
  • 用 VSCode 连别人的账号也能成功
  • 去掉免密登录、改用密码登录,依然没用

排查过程

第一步:排除 vscode-server 安装问题

VSCode Remote SSH 连上服务器后,会在服务器的 ~/.vscode-server/ 目录下自动安装 vscode-server。如果这个目录不存在或文件残缺,就会一直卡在下载阶段。

bash 复制代码
ls ~/.vscode-server/

我的目录存在且有内容,排除此原因。


第二步:排除网络问题

bash 复制代码
curl -I https://update.code.visualstudio.com

服务器可以正常访问外网,排除。


第三步:对比两个账号的 .bashrc

把自己账号和能正常连接的账号的 .bashrc 对比,发现两处差异:

差异一: 自己的 .bashrc 最后多了一行:

bash 复制代码
. "$HOME/.local/bin/env"

差异二: conda 初始化块的位置和保护方式不同。

能正常连接的账号,.bashrc 开头有:

bash 复制代码
case $- in
    *i*) ;;
      *) return;;   # 非交互式直接退出
esac

这个判断会让非交互式 shell 直接 return,后面的 conda 块碰不到。

而自己账号的 .bashrc 虽然也有这个判断,但 VSCode 使用的是 login shell ,走的是 .bash_profile → source .bashrc 这条路,$- 里没有 i 标志,导致 conda 初始化块仍然被执行,有可能在此处卡住。


第四步:模拟 VSCode 的连接方式验证

bash 复制代码
bash -li -c 'echo ok'

这条命令完全模拟了 VSCode 启动 shell 的方式。执行后立刻输出 ok,说明修改 .bashrc 之后 shell 本身没问题了。


第五步:发现真正的问题------vscode-server 残留进程

.bashrc 修复后,VSCode 依然连不上。

最终原因:服务器上有残留的旧 vscode-server 进程和缓存文件,导致新连接无法正常初始化。

bash 复制代码
pkill -f vscode-server
rm -rf ~/.vscode-server

清理完毕,重启 VSCode,重新连接,成功进入。


根本原因总结

原因 说明
.bashrc 中 conda 初始化块缺少交互式判断 VSCode 用 login shell 连接,conda 初始化被执行,可能导致卡住
vscode-server 残留进程/缓存 旧进程占用导致新连接无法初始化

两个问题叠加,导致一直转圈。


解决方案

修复 .bashrc:给 conda 初始化加上交互式判断

找到 .bashrc 中的 conda 初始化块,用 if [[ $- == *i* ]] 包裹:

bash 复制代码
# >>> conda initialize >>>
if [[ $- == *i* ]]; then
    __conda_setup="$('/home/yourname/miniconda3/bin/conda' 'shell.bash' 'hook' 2> /dev/null)"
    if [ $? -eq 0 ]; then
        eval "$__conda_setup"
    else
        if [ -f "/home/yourname/miniconda3/etc/profile.d/conda.sh" ]; then
            . "/home/yourname/miniconda3/etc/profile.d/conda.sh"
        else
            export PATH="/home/yourname/miniconda3/bin:$PATH"
        fi
    fi
    unset __conda_setup
fi
# <<< conda initialize <<<

# 同样保护其他可能卡住的初始化
if [[ $- == *i* ]]; then
    . "$HOME/.local/bin/env"
fi

效果:

  • XShell 正常登录(交互式)→ conda 正常激活,(base) 照常显示
  • VSCode 连接(非交互式)→ 跳过 conda,连接不再卡住

清理 vscode-server 残留

bash 复制代码
pkill -f vscode-server
rm -rf ~/.vscode-server

然后重启 VSCode 重新连接即可。


附:重新配置免密登录

排查过程中删掉了免密登录配置,连接成功后按以下步骤恢复。

在本地电脑的 PowerShell 中执行:

powershell 复制代码
# 如果本地没有密钥,先生成
ssh-keygen -t rsa -b 4096

# 把公钥推到服务器(替换端口和用户名)
type ~/.ssh/id_rsa.pub | ssh -p 314 yourname@your.server.ip "mkdir -p ~/.ssh && cat >> ~/.ssh/authorized_keys && chmod 600 ~/.ssh/authorized_keys"

输入一次密码后,之后 VSCode 和 XShell 都无需再输密码。


经验总结

  1. VSCode Remote SSH 连接卡住不报错,大概率是服务器端 shell 初始化问题,而不是网络或密码问题。
  2. VSCode 用的是 login shell ,和 XShell 的交互式 shell 执行路径不完全一样,.bashrc 里的 return 保护不一定能拦住 conda 初始化。
  3. 遇到莫名其妙连不上 ,先清理 ~/.vscode-server 再试,往往能解决一半问题。
  4. 排查时用 bash -li -c 'echo ok' 模拟 VSCode 的连接方式,能快速定位是否是 shell 初始化的问题。
相关推荐
上海云盾安全满满10 小时前
服务器CPU跑满的原因及解决办法
运维·服务器
tobias.b10 小时前
供电不稳定、无UPS/无双电源环境下服务器高可用完整方案
运维·服务器
scan72410 小时前
从runtime获取信息
java·服务器·前端
团象科技10 小时前
从出海业务落地视角观察 海外服务器跑开源软件的实操逻辑演变
运维·服务器·开源软件
snow@li10 小时前
nginx:详解与速查表 / Nginx = 反向代理 + 负载均衡 + 静态服务器 + HTTP 缓存 / 请求分发、静态加速、上线不中断
linux·服务器·nginx
♡来年秋风起♡10 小时前
Claude Code VSCode 插件历史记录不显示问题修复记录
ide·vscode·编辑器
小则又沐风a10 小时前
进程最终篇---进程控制(模拟实现xshell)
java·linux·服务器·前端
云服务器代理商10 小时前
阿里云国内版迁移到国际版完整操作教程
服务器·阿里云·云计算·阿里云服务器·阿里云国际·阿里云海外
阿旭超级学得完10 小时前
Linux基础指令 四(apt,vim,git,cgdb)
linux·服务器·开发语言·数据结构·c++·git·vim
半夜修仙10 小时前
4.RabbitMQ运维
linux·运维·服务器·分布式·rabbitmq·java-rabbitmq