知识共享许可协议
本作品采用知识共享署名-非商业性使用 3.0 未本地化版本许可协议进行许可。

Node.js v4.2.4 手册 & 文档


调试器#

稳定度: 3 - 稳定

V8 提供了一个强大的调试器,可以通过 TCP 协议从外部访问。Node 内建了这个调试器的客户端。要使用调试器,以 debug 参数启动 Node,出现提示符:

% node debug myscript.js
< debugger listening on port 5858
connecting... ok
break in /home/indutny/Code/git/indutny/myscript.js:1
  1 x = 5;
  2 setTimeout(function () {
  3   debugger;
debug>

Node 的调试器客户端并未完整支持所有命令,但简单的步进和检查是可行的。通过脚本的源代码中放置 debugger; 语句,您便可启用一个断点。

比如,假设有一个类似这样的 myscript.js

// myscript.js
x = 5;
setTimeout(function () {
  debugger;
  console.log("world");
}, 1000);
console.log("hello");

那么,当调试器运行时,它会在第 4 行中断:

% node debug myscript.js
< debugger listening on port 5858
connecting... ok
break in /home/indutny/Code/git/indutny/myscript.js:1
  1 x = 5;
  2 setTimeout(function () {
  3   debugger;
debug> cont
< hello
break in /home/indutny/Code/git/indutny/myscript.js:3
  1 x = 5;
  2 setTimeout(function () {
  3   debugger;
  4   console.log("world");
  5 }, 1000);
debug> next
break in /home/indutny/Code/git/indutny/myscript.js:4
  2 setTimeout(function () {
  3   debugger;
  4   console.log("world");
  5 }, 1000);
  6 console.log("hello");
debug> repl
Press Ctrl + C to leave debug repl
> x
5
> 2+2
4
debug> next
< world
break in /home/indutny/Code/git/indutny/myscript.js:5
  3   debugger;
  4   console.log("world");
  5 }, 1000);
  6 console.log("hello");
  7
debug> quit
%

repl 命令允许您远程执行代码;next 命令步进到下一行。此外还有一些其它命令,输入 help 查看。

监视器#

调试代码时您可以监视表达式或变量值。在每个断点中监视器列表中的各个表达式会被以当前上下文执行,并在断点的源代码前显示。

输入 watch("my_expression") 开始监视一个表达式;watchers 显示活动监视器;unwatch("my_expression") 移除一个监视器。

命令参考#

步进#

  • cont, c - 继续执行
  • next, n - Step next
  • step, s - Step in
  • out, o - Step out
  • pause - 暂停执行代码(类似开发者工具中的暂停按钮)

断点#

  • setBreakpoint(), sb() - 在当前行设置断点
  • setBreakpoint(line), sb(line) - 在指定行设置断点
  • setBreakpoint('fn()'), sb(...) - 在函数体的第一条语句设置断点
  • setBreakpoint('script.js', 1), sb(...) - 在 script.js 的第一行设置断点
  • clearBreakpoint, cb(...) - 清除断点

在一个尚未被加载的文件(模块)中设置断点也是可行的:

% ./node debug test/fixtures/break-in-module/main.js
< debugger listening on port 5858
connecting to port 5858... ok
break in test/fixtures/break-in-module/main.js:1
  1 var mod = require('./mod.js');
  2 mod.hello();
  3 mod.hello();
debug> setBreakpoint('mod.js', 23)
Warning: script 'mod.js' was not loaded yet.
  1 var mod = require('./mod.js');
  2 mod.hello();
  3 mod.hello();
debug> c
break in test/fixtures/break-in-module/mod.js:23
 21
 22 exports.hello = function() {
 23   return 'hello from module';
 24 };
 25
debug>

信息#

  • backtrace, bt - 显示当前执行框架的回溯
  • list(5) - 显示脚本源代码的 5 行上下文(之前 5 行和之后 5 行)
  • watch(expr) - 向监视列表添加表达式
  • unwatch(expr) - 从监视列表移除表达式
  • watchers - 列出所有监视器和它们的值(每个断点会自动列出)
  • repl - 在所调试的脚本的上下文中打开调试器的 repl 执行代码

执行控制#

  • run - 运行脚本(调试器开始时自动运行)
  • restart - 重新运行脚本
  • kill - 终止脚本

杂项#

  • scripts - 列出所有已加载的脚本
  • version - 显示 V8 的版本

高级使用#

V8 调试器可以从两种方式启用和访问:以 --debug 命令行标志启动 Node;或者向已存在的 Node 进程发送 SIGUSR1 信号。

一旦一个进程进入了调试模式,它便可被 Node 调试器连接。调试器可以通过 pid 或 URI 来连接,语法是:

  • node debug -p <pid> - 通过 pid 连接进程
  • node debug <URI> - 通过类似 localhost:5858 的 URI 连接进程