如何用VSCode的远程开发功能连接Linux服务器进行编程【教程】
发布时间 - 2026-01-25 00:00:00 点击率:次VSCode远程开发能否成功取决于vscode-server在服务器端的静默安装与稳定运行,关键条件包括SSH密钥认证、glibc≥2.17、可访问update.code.visualstudio.com、主目录≥200MB空间、用户拥有有效shell及完整PATH环境变量。
vscode 的远程开发功能不是“连上就能写代码”,关键在于 vscode-server 能否在目标 linux 服务器上静默安装并稳定运行——这取决于 ssh 权限、glibc 版本、磁盘空间和网络代理设置,而不是 vscode 本地版本新旧。
确认服务器满足 vscode-server 运行前提
VSCode 远程连接本质是通过 SSH 启动服务器端的 vscode-server(一个轻量 Node.js 服务),它对环境有硬性要求:
-
glibc >= 2.17(CentOS 7+ / Ubuntu 16.04+ 基本达标;老旧 CentOS 6 或嵌入式系统大概率失败) - 服务器需能访问
update.code.visualstudio.com(若走公司代理或离线环境,需手动下载vscode-server并放至~/.vscode-server/bin/对应 commit ID 目录) - 用户主目录磁盘剩余空间 ≥ 200MB(
vscode-server解压后约 150MB,临时文件另计) - SSH 用户必须有
shell(不能是/bin/false或/usr/sbin/nologin)且可执行bash和tar
用 SSH 密钥而非密码登录,避免反复输密码中断连接
VSCode 远程插件在首次建立连接、自动部署 vscode-server、后续心跳保活时,会多次调用 SSH。如果配置的是密码认证,每次都会弹窗,极易导致超时失败。
- 本地生成密钥:
ssh-keygen -t ed25519 -C "your_email@example.com" - 上传公钥到服务器:
ssh-copy-id -i ~/.ssh/id_ed25519.pub user@host(确保~/.ssh/authorized_keys权限为600) - 检查服务器
/etc/ssh/sshd_config是否启用:PubkeyAuthentication yes,改完记得sudo systemctl restart sshd - VSCode 中点击左下角远程连接图标 → “Connect to Host…” → 输入
user@host即可免密直连
连接后无法打开终端或提示 command 'workbench.action.terminal.new' not found
这不是插件没装,而是远程服务器缺少基础 shell 工具链。VSCode 终端依赖服务器上真实可用的 bash、sh 或 zsh,且其 $PATH 必须包含常用命令路径。
- 先手动 SSH 登录服务器,执行
which bash和echo $PATH,确认返回正常 - 检查
/etc/passwd中该用户登录 shell 是否真实存在(例如写成/bin/bash但实际只有/usr/bin/bash) - 某些最小化安装系统(如 Alpine、CoreOS)默认无
bash,需apk或
add bash
apt install bash - VSCode 设置中搜索
terminal.integrated.defaultProfile.linux,手动设为服务器上存在的 shell 路径,例如/usr/bin/bash
编辑大文件卡顿、Git 操作慢、文件监视失效
VSCode 默认把文件监视(file watching)、Git 状态扫描、语法校验全放在远程服务器执行。当服务器资源紧张或文件系统为 NFS / CIFS 时,这些操作会严重拖慢响应。
- 禁用远程文件监视:在远程设置(
settings.json)中加"files.useExperimentalFileWatcher": false - 把 Git 操作交由本地处理:设置
"git.enabled": false(远程) + 本地克隆同一仓库 + 用git remote set-url origin指向服务器 Git 仓库路径 - 大项目建议关闭不必要的扩展:远程侧只保留
Python、C/C++等语言支持类扩展,禁用Live Share、Remote Explorer等非必需项 - 若服务器 CPU 或内存长期 >80%,考虑在本地用
rsync同步代码 + 远程仅做构建/调试(即“本地编辑 + 远程编译”模式)
最常被忽略的一点:VSCode 远程连接成功 ≠ 开发环境就绪。很多问题(比如 Python 插件找不到解释器、调试器断点不生效)根源不在连接本身,而在于 vscode-server 启动时加载的 shell 环境变量与你手动 SSH 登录时不一致——它默认不读取 ~/.bashrc 或 ~/.zshrc,需要显式配置 "remote.SSH.env" 或在 ~/.bash_profile 中补全 PATH。
# linux
# python
# centos
# vscode
# js
# node.js
# git
# json
# node
# ubuntu
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
中山网站推广排名,中山信息港登录入口?
怎么用AI帮你设计一套个性化的手机App图标?
javascript中闭包概念与用法深入理解
Laravel怎么实现观察者模式Observer_Laravel模型事件监听与解耦开发【指南】
Windows10如何删除恢复分区_Win10 Diskpart命令强制删除分区
JavaScript如何实现继承_有哪些常用方法
如何在 React 中条件性地遍历数组并渲染元素
免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?
ChatGPT回答中断怎么办 引导AI继续输出完整内容的方法
Laravel如何发送邮件和通知_Laravel邮件与通知系统发送步骤
如何用景安虚拟主机手机版绑定域名建站?
如何用PHP快速搭建高效网站?分步指南
JavaScript如何实现倒计时_时间函数如何精确控制
如何在云虚拟主机上快速搭建个人网站?
js实现获取鼠标当前的位置
Laravel怎么配置自定义表前缀_Laravel数据库迁移与Eloquent表名映射【步骤】
Python正则表达式进阶教程_复杂匹配与分组替换解析
Laravel如何生成URL和重定向?(路由助手函数)
手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?
网站图片在线制作软件,怎么在图片上做链接?
武汉网站设计制作公司,武汉有哪些比较大的同城网站或论坛,就是里面都是武汉人的?
Mybatis 中的insertOrUpdate操作
Laravel队列任务超时怎么办_Laravel Queue Timeout设置详解
PHP 500报错的快速解决方法
如何用花生壳三步快速搭建专属网站?
深圳防火门网站制作公司,深圳中天明防火门怎么编码?
如何快速生成可下载的建站源码工具?
Laravel如何与Inertia.js和Vue/React构建现代单页应用
浅析上传头像示例及其注意事项
头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?
公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?
Laravel如何使用模型观察者?(Observer代码示例)
如何用好域名打造高点击率的自主建站?
什么是javascript作用域_全局和局部作用域有什么区别?
如何快速搭建自助建站会员专属系统?
微信小程序 wx.uploadFile无法上传解决办法
php485函数参数是什么意思_php485各参数详细说明【介绍】
香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化
网站制作软件免费下载安装,有哪些免费下载的软件网站?
ChatGPT怎么生成Excel公式_ChatGPT公式生成方法【指南】
Laravel如何构建RESTful API_Laravel标准化API接口开发指南
Laravel如何实现全文搜索_Laravel Scout集成Algolia或Meilisearch教程
百度输入法ai组件怎么删除 百度输入法ai组件移除工具
北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?
Laravel如何实现多表关联模型定义_Laravel多对多关系及中间表数据存取【方法】
javascript中的数组方法有哪些_如何利用数组方法简化数据处理
laravel怎么通过契约(Contracts)编程_laravel契约(Contracts)编程方法
DeepSeek是免费使用的吗 DeepSeek收费模式与Pro版本功能详解
Laravel怎么进行浏览器测试_Laravel Dusk自动化浏览器测试入门
消息称 OpenAI 正研发的神秘硬件设备或为智能笔,富士康代工
下一篇:SQL 中函数调用的代价分析
下一篇:SQL 中函数调用的代价分析


