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 都无需再输密码。
经验总结
- VSCode Remote SSH 连接卡住不报错,大概率是服务器端 shell 初始化问题,而不是网络或密码问题。
- VSCode 用的是 login shell ,和 XShell 的交互式 shell 执行路径不完全一样,
.bashrc里的return保护不一定能拦住 conda 初始化。 - 遇到莫名其妙连不上 ,先清理
~/.vscode-server再试,往往能解决一半问题。 - 排查时用
bash -li -c 'echo ok'模拟 VSCode 的连接方式,能快速定位是否是 shell 初始化的问题。