Ubuntu上Node.js应用如何调试
Ubuntu 上 Node.js 应用调试指南

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈
一 内置调试与 Chrome DevTools
想快速上手调试?Node.js 自带的内置调试器配合 Chrome DevTools,堪称黄金搭档。
- 启动方式
- 普通调试:运行命令
node --inspect app.js,调试器便会启动,默认在 9229 端口上恭候大驾。 - 首行即停:如果你希望从程序入口第一行就开始细细品味,那就用
node --inspect-brk app.js命令,它会立刻在起点暂停。
- 普通调试:运行命令
- 连接与断点
- 接下来,在 Chrome 浏览器地址栏输入
chrome://inspect。在 “Remote Target” 区域找到你的应用,点击 “inspect”,熟悉的 DevTools 界面就出现了。 - 在 “Sources” 面板里,你可以自由地设置断点、单步执行、观察作用域变量和调用栈,一切尽在掌握。
- 还有个偷懒的小技巧:在代码里直接插入
debugger;语句,配合--inspect启动,程序运行到这儿就会自动暂停。
- 接下来,在 Chrome 浏览器地址栏输入
- 无界面/自动重启场景
- 开发时习惯用 nodemon 实现热重载?调试也没问题。使用
nodemon --inspect app.js即可。如果偶尔遇到断点不生效的情况,别急,关闭 DevTools 再重新打开连接一次,通常就能解决。
- 开发时习惯用 nodemon 实现热重载?调试也没问题。使用
二 使用 VSCode 调试
对于习惯在 VSCode 里编码的开发者来说,其内置的调试功能用起来会更加顺手,几乎无需离开这个强大的编辑器。
- 快速配置
- 打开项目后,找到左侧的“运行和调试”图标,点击它并创建
.vscode/launch.json文件,环境选择 Node.js。 - 一个常用的配置示例如下(记得根据实际情况修改
program字段指向你的入口文件):{ “version”: “0.2.0”, “configurations”: [{ “type”: “node”, “request”: “launch”, “name”: “Launch Program”, “program”: “${workspaceFolder}/app.js”, “console”: “integratedTerminal” }] }
- 打开项目后,找到左侧的“运行和调试”图标,点击它并创建
- 启动与常用控制
- 在代码行号左侧点击即可设置断点,然后按 F5 启动调试。执行控制就靠几个快捷键:F10(跳过)、F11(跳入)、Shift+F11(跳出)。
- 有个贴心建议:将
console设置为integratedTerminal,这样应用的输入输出和调试信息都在终端里,交互起来更清晰。
- 附加到已运行进程
- 有时候应用已经跑起来了,怎么调试?先确保它以调试模式启动:
node --inspect=9229 app.js(或者用--inspect-brk)。 - 然后在
launch.json里增加一个配置:{ “name”: “Attach to Node”, “type”: “node”, “request”: “attach”, “port”: 9229, “restart”: true } - 最后在调试下拉菜单中选择 “Attach to Node”,就能轻松连接到正在运行的进程进行调试了。
- 有时候应用已经跑起来了,怎么调试?先确保它以调试模式启动:
三 使用 PM2 运行与调试
当应用进入生产环境或需要进程管理时,PM2 是常见选择。它同样能和调试器完美协作。
- 日志与实时排查
- 查看全部应用日志:
pm2 logs - 查看指定应用:
pm2 logs - 实时跟踪:
pm2 logs --follow;查看最近 N 行:pm2 logs --lines 1000
- 查看全部应用日志:
- 与调试器配合
- 用调试模式启动应用:
pm2 start app.js --node-args=“--inspect=9229” - 如果需要文件改动热重载:
pm2 start app.js --node-args=“--inspect=9229” --watch - 启动后,你就可以像之前一样,在 VSCode 里使用 “Attach to Node” 配置连接 9229 端口,或者在 Chrome 中打开
chrome://inspect进行远程调试了。
- 用调试模式启动应用:
四 日志与常见故障排查
调试器是利器,但日志分析才是日常定位问题的基本功。结合一些常见的 Node.js 警告,能帮你快速缩小排查范围。
- 日志定位
- 应用日志:首先检查项目自身配置的日志文件,比如
app.log、error.log等。使用tail -f /path/to/file.log命令可以实时查看最新动态。 - 系统日志:如果应用以系统服务方式运行,可以查看
journalctl -u。更通用的系统日志则位于/var/log/syslog。
- 应用日志:首先检查项目自身配置的日志文件,比如
- 常见 Node.js 警告与处理
- DeprecationWarning:这通常是使用了过时的 API,比如旧的
Buffer()构造函数。解决办法是改用Buffer.alloc()或Buffer.from(),并记得升级相关依赖和 Node.js 版本。 - UnhandledPromiseRejectionWarning:未处理的 Promise 拒绝。务必为所有 Promise 链添加
.catch()处理,或者在 async 函数中使用 try/catch。临时排查时,可以监听process.on(‘unhandledRejection’)事件。 - MaxListenersExceededWarning:事件监听器数量超限,可能存在内存泄漏。检查代码中是否重复添加了监听器而未移除,适时使用
removeListener,或者通过setMaxListeners临时调高限制。 - Ja vaScript heap out of memory:Ja vaScript 堆内存不足。临时解决方案是启动时增加堆上限:
node --max-old-space-size=4096 app.js。要根治问题,则需要使用 clinic 等专业工具进行深入的内存分析。
- DeprecationWarning:这通常是使用了过时的 API,比如旧的
五 实用提示
最后,分享几个能提升调试效率的小贴士。
- 端口与远程调试
- 记住,调试默认端口是 9229。在远程服务器或 Docker 容器内调试时,务必确保该端口在网络上可达。必要时,可以通过
--inspect=来指定监听的地址和端口。:
- 记住,调试默认端口是 9229。在远程服务器或 Docker 容器内调试时,务必确保该端口在网络上可达。必要时,可以通过
- 条件断点与观察表达式
- 无论是 Chrome DevTools 还是 VSCode,都支持设置条件断点和日志点(logpoint)。在调试控制台里观察和计算表达式,能让你快速验证假设,精准定位问题。
- 快速输出排查
- 在复杂的逻辑中,临时使用
console.log或console.error进行输出,依然是快速定位问题的有效手段。为了不影响生产环境,可以通过条件编译或环境变量来控制这些调试日志的输出级别。
- 在复杂的逻辑中,临时使用
相关攻略
在 Ubuntu 上更新 Python 的可选方案与步骤 一 方法总览与选择建议 面对 Ubuntu 系统上 Python 版本的更新需求,其实有几种主流路径可选。每种方法都有其特定的适用场景,选择的关键在于平衡便捷性、隔离性与对现有系统的影响。 简单来说,你可以考虑以下四种方案: 使用 APT +
在 Ubuntu 上安装与运行 Python 程序 一、安装 Python 解释器 万事开头难,但安装Python解释器这事儿,其实不难。关键在于选对方法。 使用系统包管理器安装(推荐) 打开终端,先更新软件源索引,然后直接安装:sudo apt update && sudo apt install
Ubuntu 中 Python 的安装与环境配置教程 一 安装前准备 在开始安装之前,先做好这几项准备工作,能让后续过程顺畅不少。 更新索引并升级系统: 打开终端,首先运行这条命令,确保你的软件包列表是最新的,同时升级所有可更新的包: sudo apt update && sudo apt upgr
在 Ubuntu 上安装与配置 Python 环境 一 快速开始 APT 安装 对于大多数用户来说,最直接、最省心的方式,莫过于使用 Ubuntu 自带的包管理器 APT。这个方法的好处是,安装的 Python 与系统其他组件的兼容性最好,几乎不会出现依赖冲突的问题。 更新索引并安装基础组件: su
优化Ubuntu上的PHP会话管理 想让你的Ubuntu服务器上PHP应用跑得更稳、更快、更安全吗?会话管理这块,往往是性能瓶颈和安全风险的藏身之处。今天,我们就来聊聊几个立竿见影的优化策略。 1 选择合适的会话存储方式 别总让会话数据躺在默认的文件系统里。随着流量增长,文件I O很容易成为拖慢应
热门专题
热门推荐
WF-1000XM4蓝牙配对指南:两种触发路径,一个核心逻辑 给索尼WF-1000XM4配对,核心其实就一件事:让耳机进入“被发现”的状态。有意思的是,它并不依赖某个单一的物理按键,而是提供了双路径的触发方式。根据官方的操作指南以及多次的实际测试,无论是通过充电盒上的功能键,还是直接操作耳机本身,都
迅捷路由器桥接失败怎么办?原因分析与解决方法大全 许多用户在使用迅捷路由器进行无线桥接时,经常遇到“显示已连接但无法访问互联网”的问题。实际上,这通常并非设备故障,而是由于关键的网络参数配置不当或主副路由器之间的通信协调不畅所致。简单来说,就是两台路由器之间的设置没有完全匹配。那么,具体哪些环节最容
迅捷路由器无线桥接:手机端设置实操指南 使用手机为迅捷路由器配置无线桥接(WDS),听似专业,实则通过官方适配的移动端界面就能轻松完成。只要满足几个关键条件,您仅需一部手机即可高效架设扩展网络。操作时,请先将手机连接至副路由器的默认无线信号(通常以FAST_XXXX格式命名),随后在Safari或C
小米空调联网故障全解析:从新手排查到专家级修复,步步为营 当小米空调始终无法成功连接网络时,许多用户的第一反应往往是联系售后或怀疑设备故障。然而实际情况是,超过九成的联网失败案例,根源都出在网络配置、操作流程这类“软性”环节,空调硬件本身出问题的概率极低。解决问题的核心在于掌握系统化的排查思路,按照
有线音响加装蓝牙功能并不复杂,普通用户借助外置蓝牙接收器即可在十分钟内完成升级 想给家里的老款有线音响“剪掉”那根烦人的音频线?其实这件事没你想的那么复杂。普通用户完全不需要动用电烙铁,借助一个小巧的外置蓝牙接收器,十分钟之内就能搞定升级。核心操作很简单:确认你的音箱背面有标准的3 5毫米或RCA音





