0

0

如何用vscode进行node.js服务器调试【教程】

狼影

狼影

发布时间:2026-01-21 15:43:26

|

934人浏览过

|

来源于php中文网

原创

VS Code调试Node.js服务器最稳定方式是node --inspect启动后attach,需配对launch.json端口;直接launch易因路径、环境变量或sourcemap配置错误导致断点失效。

vs code 调试 node.js 服务器不需要装插件也能跑起来,但必须配对 launch.json 和启动方式,否则断点不生效、进程自动退出、console.log 看不到输出都是常见现象。

node --inspect 启动服务再 attach

这是最稳定、兼容性最好的方式,尤其适合 Express/Koa/Nest 等框架启动较慢或带 CLI 参数的场景。VS Code 不接管进程生命周期,只“附着”上去调试。

  • 终端里手动运行:node --inspect=9229 ./bin/www(假设你的入口是 ./bin/www
  • VS Code 中按 Ctrl+Shift+D 打开调试面板,点击左上角齿轮图标生成 .vscode/launch.json,选 Node.js: Attach to Process
  • 确保 port 和启动命令一致(默认 9229),保存后点击绿色 ▶ 启动 attach
  • 注意:如果服务启动后立刻退出(比如没监听端口),--inspect 会失效——加 --inspect-brk 可在第一行暂停,等你设好断点再继续

launch.json 直接 launch 时的路径和环境陷阱

Node.js: Launch Program 模板看似简单,但 programcwdenv 配错会导致模块找不到、process.env 为空、require('./config') 报错。

  • "program": "${workspaceFolder}/app.js" —— 必须写绝对路径,${workspaceFolder} 是安全写法;别用 ./app.js
  • "cwd": "${workspaceFolder}" —— 控制工作目录,影响 require() 解析和 fs.readFile('./data.json')
  • 需要环境变量?直接加:"env": { "NODE_ENV": "development", "PORT": "3001" },别依赖 .env 文件(除非你自己用 dotenv 加载)
  • 如果用 ts-nodenodemon,不能直接填进 program;得用 runtimeExecutable 指定解释器

断点不命中?检查这三个地方

不是代码问题,大概率是 sourcemap、文件映射或 VS Code 缓存导致的假象。

站长俱乐部购物系统
站长俱乐部购物系统

功能介绍:1、模块化的程序设计,使得前台页面设计与程序设计几乎完全分离。在前台页面采用过程调用方法。在修改页面设计时只需要在相应位置调用设计好的过程就可以了。另外,这些过程还提供了不同的调用参数,以实现不同的效果;2、阅读等级功能,可以加密产品,进行收费管理;3、可以完全可视化编辑文章内容,所见即所得;4、无组件上传文件,服务器无需安装任何上传组件,无需支持FSO,即可上传文件。可限制文件上传的类

下载
  • TS/JSX 项目必须生成 .map 文件:TS 编译时加 "sourceMap": true,且 outDirrootDir 对齐
  • 调试时看到的是编译后 JS,但断点打在 TS 上——确认 launch.json 里有 "sourceMaps": true"outFiles": ["${workspaceFolder}/dist/**/*.js"]
  • 改了 launch.json 或代码后没重启调试会话?VS Code 不自动重载配置,必须停掉再点 ▶
  • Express 路由里断点不触发?先确认请求真发到了这个路由(看终端日志或加 console.log('hit')),再检查是否用了 router.use() 顺序错位

最麻烦的其实是异步链路:Promise.then()、async/await、中间件嵌套多层后,堆跳转快,断点容易“跳过”。这时候别只盯着一行代码,打开调试面板的 “Call Stack” 和 “Loaded Scripts”,看当前执行位置到底落在哪一层文件里。

相关专题

更多
什么是中间件
什么是中间件

中间件是一种软件组件,充当不兼容组件之间的桥梁,提供额外服务,例如集成异构系统、提供常用服务、提高应用程序性能,以及简化应用程序开发。想了解更多中间件的相关内容,可以阅读本专题下面的文章。

178

2024.05.11

Golang 中间件开发与微服务架构
Golang 中间件开发与微服务架构

本专题系统讲解 Golang 在微服务架构中的中间件开发,包括日志处理、限流与熔断、认证与授权、服务监控、API 网关设计等常见中间件功能的实现。通过实战项目,帮助开发者理解如何使用 Go 编写高效、可扩展的中间件组件,并在微服务环境中进行灵活部署与管理。

213

2025.12.18

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

415

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

533

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

310

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

75

2025.09.10

require的用法
require的用法

require的用法有引入模块、导入类或方法、执行特定任务。想了解更多require的相关内容,可以阅读本专题下面的文章。

466

2023.11.27

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

392

2023.07.18

Java编译相关教程合集
Java编译相关教程合集

本专题整合了Java编译相关教程,阅读专题下面的文章了解更多详细内容。

5

2026.01.21

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
go语言零基础开发内容管理系统
go语言零基础开发内容管理系统

共34课时 | 2.6万人学习

第二十三期_前端开发
第二十三期_前端开发

共98课时 | 7.5万人学习

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

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