Node.js v0.10.31API手册-Debugger

Debugger

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 查看。

Watchers(监视器)

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

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

Commands reference(命令参考)

Stepping(进步)

  • contc -
    继续执行
  • nextn -
    Step next
  • steps -
    Step in
  • outo -
    Step out
  • pause - 暂停执行代码(类似开发者工具中的暂停按钮)

Breakpoints(断点)

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

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

% ./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>

Info(信息)

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

Execution control(执行控制)

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

Various(其他)

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

Advanced Usage(高级)

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

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

  • node debug -p <pid> - 通过 pid 连接进程
  • node debug <URI> - 通过类似 localhost:5858 的 URI 连接进程
时间: 2024-08-02 10:46:09

Node.js v0.10.31API手册-Debugger的相关文章

Node.js v0.10.31API手册-Domain

Node.js v0.10.31API手册-目录 Domain(域) Domains 提供了一种方式,即以一个单一的组的形式来处理多个不同的IO操作.如果任何一个注册到domain的事件触发器或回调触发了一个'error'事件,或者抛出一个错误,那么domain对象将会被通知到.而不是直接让这个错误的上下文从`process.on('uncaughtException')'处理程序中丢失掉,也不会致使程序因为这个错误伴随着错误码立即退出. 警告: 不要忽视错误! Domain error处理程序

Node.js v0.10.31API手册-事件

Node.js v0.10.31API手册-目录 Events(事件) Node里面的许多对象都会分发事件:一个net.Server对象会在每次有新连接时分发一个事件, 一个fs.readStream对象会在文件被打开的时候发出一个事件. 所有这些产生事件的对象都是events.EventEmitter的实例. 你可以通过require("events")来访问该模块. 通常,事件名是驼峰命名 (camel-cased) 的字符串.不过也没有强制的要求,任何字符串都是可以使用的. 为了

Node.js v0.10.31API手册-DNS

原API变化,故译文与之前译文样式上有所不同 Node.js v0.10.31API手册-目录 DNS 使用 require('dns') 引入此模块.dns 模块中的所有方法都使用了 C-Ares,除了 dns.lookup 使用了线程池中的 getaddrinfo(3).C-Ares 比 getaddrinfo 要快得多,但系统解析器相对于其它程序的操作要更固定.当一个用户使用 net.connect(80, 'google.com') 或 http.get({ host: 'google.

Node.js v0.10.31API手册-目录

这段时间,想找些新的技术学习学习,看上了Node.js,万丈高楼平地起,这就从它的API开始,然后就顺便翻译一下. Node.js v0.10.31API手册-简介 Node.js v0.10.31API手册-断言 Node.js v0.10.31API手册-Buffer Node.js v0.10.31API手册-Addons插件 持续更新中...

Node.js v0.10.31API手册-加密

加密(Crypto) 使用 require('crypto') 来调用该模块. crypto模块提供在HTTPS或HTTP连接中封装安全凭证的方法. 它提供OpenSSL中的一系列哈希方法,包括hmac.cipher.decipher.签名和验证等方法的封装. crypto.getCiphers() 返回一个数组,包含支持的加密算法的名字. 示例: var ciphers = crypto.getCiphers(); console.log(ciphers); // ['AES-128-CBC'

Node.js v0.10.31API手册-集群

集群 单个 Node 实例运行在单个线程中.要发挥多核系统的能力,用户有时候需要启动一个 Node 进程集群来处理负载. 集群模块允许你方便地创建一个共享服务器端口的进程网络. var cluster = require('cluster'); var http = require('http'); var numCPUs = require('os').cpus().length; if (cluster.isMaster) { // Fork workers. for (var i = 0;

Node.js v0.10.31API手册-子进程

子进程 Node 通过 child_process 模块提供了类似 popen(3) 的处理三向数据流(stdin/stdout/stderr)的功能. 它能够以完全非阻塞的方式与子进程的 stdin.stdout 和 stderr 以流式传递数据.(请注意,某些程序在内部使用行缓冲 I/O.这不会影响到 node.js,但您发送到子进程的数据不会被立即消费.) 使用 require('child_process').spawn()或者 require('child_process').fork

Node.js v0.10.31API手册-Addons插件

Addons Addons插件就是动态连接库.Addons插件将Node与C库和C++库链接起来.它的API(目前来说)相当复杂,涉及到了几个类库的知识. V8 JavaScript引擎是一个 C++ 类库..用于和JavaScript进行交互的接口.创建对象, 调用函数等. 文档大部分在这里:v8.h 头文件 (deps/v8/include/v8.h在Node源代码目录里), 也有可用的线上文档线上. libuv, C语言编写的事件循环类库.任何时候需要等待一个文件描述符变为可读状态,等待一

Node.js v0.10.31API手册-控制台

控制台 Object 用于向 stdout 和 stderr 打印字符.类似于大部分 Web 浏览器提供的 console 对象函数,在这里则是输出到 stdout 或 stderr. 当输出目标是一个终端或者文件时,console函数是同步的(为了防止过早退出时丢失信息).当输出目标是一个管道时它们是异步的(防止阻塞过长时间). 也就是说,在下面的例子中,stdout 是非阻塞的,而 stderr 则是阻塞的. $ node script.js 2> error.log | tee info.