0

0

利用VSCode进行远程调试(Remote Debugging)的多种方式

P粉986688829

P粉986688829

发布时间:2026-01-02 16:03:09

|

554人浏览过

|

来源于php中文网

原创

VSCode远程调试依赖Remote-SSH、Remote-Containers和Remote-WSL三大扩展,配合语言调试器配置,实现本地编辑、远程运行与断点调试;还可通过手动Attach模式接入已有进程。

利用vscode进行远程调试(remote debugging)的多种方式

VSCode 的远程调试能力非常灵活,主要靠 Remote - SSHRemote - ContainersRemote - WSL 三大扩展支撑,再配合调试器(如 Python、Node.js、Go 等)的适配配置,就能在本地编辑、远程运行、断点调试一气呵成。

通过 Remote - SSH 连接远程服务器调试

这是最常用的方式,适合调试部署在 Linux 服务器上的应用。

  • 先在 VSCode 中安装 Remote - SSH 扩展,配置好 SSH 密钥或密码登录方式
  • Ctrl+Shift+PRemote-SSH: Connect to Host... 连上目标机器,VSCode 会自动在远程启动服务端(vscode-server)
  • 打开远程项目文件夹后,在本地写代码,所有操作(包括调试)都实时作用于远程环境
  • 调试前确保远程已安装对应语言的调试支持(比如 Python 需要 ptvsd 或内置 debugpy;Node.js 默认支持)
  • .vscode/launch.json 中配置 "remoteRoot""port"(如需端口转发),并启用 "justMyCode": true 避免跳进系统库

在 Docker 容器中调试(Remote - Containers)

适合微服务、CI/CD 测试环境或依赖隔离的开发场景。

  • 安装 Remote - Containers 扩展,确保本机已装 Docker Desktop 并运行正常
  • 在项目根目录放好 Dockerfiledocker-compose.yml,再加一个 .devcontainer/devcontainer.json
  • Ctrl+Shift+PDev Containers: Reopen in Container,VSCode 会构建镜像、启动容器、挂载源码、安装扩展
  • 调试时,launch.json 中设置 "type": "python"(或其他)即可直接 Attach 或 Launch,路径映射由 devcontainer 自动处理
  • 注意:如果容器内服务监听 127.0.0.1,外部无法访问,应改用 0.0.0.0;端口需在 devcontainer.json 中用 "forwardPorts" 显式声明

利用 WSL 本地调试 Linux 环境代码

Windows 用户无需虚拟机,就能获得接近原生 Linux 的调试体验。

Amazon Nova
Amazon Nova

亚马逊云科技(AWS)推出的一系列生成式AI基础模型

下载
  • 启用 WSL2,安装发行版(如 Ubuntu),再在 VSCode 中安装 Remote - WSL 扩展
  • 打开 WSL 文件系统(例如 \\wsl$\Ubuntu\home\user\project),VSCode 会自动切换到 WSL 后端
  • 所有终端、调试器、Python 解释器都默认使用 WSL 内的环境,无需额外配置路径或解释器路径
  • 调试 Python 时,可直接选 WSL 中的 python3;调试 Node.js 时,确保 node 命令在 WSL PATH 中
  • 图形界面程序(如带 GUI 的 Python 应用)需要额外配置 X Server(如 VcXsrv),但纯命令行和 Web 服务调试完全无感

手动 Attach 到远程进程(通用补充方式)

当无法用上述方式接管整个环境时(比如已有进程在跑),可用 Attach 模式介入调试。

  • 以 Python 为例:在远程脚本开头加入 import debugpy; debugpy.listen(5678); debugpy.wait_for_client()
  • 在本地 launch.json 中配置 "request": "attach",指定 "host"(如 "localhost")和 "port"(如 5678
  • 若远程服务不在本机可直连网络,可通过 SSH 端口转发打通:执行 ssh -L 5678:localhost:5678 user@remote
  • Node.js 可用 node --inspect=0.0.0.0:9229 script.js,然后本地 launch.json 设置 "port": 9229 并启用端口转发
  • Attach 模式不重启进程,适合热修复、线上问题复现等场景

基本上就这些。三种 Remote 扩展覆盖了绝大多数远程调试需求,手动 Attach 是兜底手段。关键是根据运行环境选对入口,再把调试器配置对路——路径、端口、监听地址、权限这几点卡住了,八成是调试连不上。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

720

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

627

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

744

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

617

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1236

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

547

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

575

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

700

2023.08.11

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

74

2025.12.31

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 6.4万人学习

Git 教程
Git 教程

共21课时 | 2.4万人学习

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

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