nodeJS教程(二)、nodejs调试

一、基于nodejs内建的调试

node.js本身支持调试,在js文件中加上debbuger或者在cmd中通过setBreakpoint()可以添加断点。

要使用nodejs的调试服务,只要在启动命令时加上debug。如:node debug web.js。

nodeJS教程(二)、nodejs调试

这时候输入一些指令就能够单步调试、监视变量。

命令 功能
backtrace, bt 显示当前的调用栈
clearBreakpoint, cb(...) 清除所有断点
cont, c 继续执行,直到遇到下一个断点
kill 终止当前执行的脚本
list(n) 显示当前执行到的前后n行代码
next, n 单步执行
out, o 从函数中步出
repl 在当前上下文打开即时求值环境
restart 重新执行脚本
run 执行脚本,在第一行暂停
scripts 显示当前已加载的所有脚本
setBreakpoint(), sb() 当前行设置断点
setBreakpoint('fn()'), sb(...) 在函数fn的第一行设置断点
setBreakpoint('app.js', 20), sb(...) 在 app.js 的第20行设置断点
step, s 单步执行并进入函数
unwatch(expr)  把表达式 expr 从监视列表移除 
version 显示v8版本
watch(expr) 把表达式 expr 加入监视列表
watchers 显示监视列表中所有的表达式和值

比如web.js文件如下:

var http = require("http");
http.createServer(function(request, response) {
    response.writeHead(200, {'Content-Type': 'text/plain'});
	response.write("111");
	debugger;
	response.end("222");
	debugger;
}).listen(8000);

在上面的命令行输入cont之后会监听服务。客户端打开http://127.0.0.1:8000/后,这时候会进入第一个断点(第6行)。输入repl,就能够查看当前上下文变量。退出repl后,输入cont可以进入下一个断点。

nodeJS教程(二)、nodejs调试

二、内置node-inspect+chrome调试

全局安装node-inspect:npm install -g node-inspect

nodeJS教程(二)、nodejs调试

cmd中输入:node --inspect-brk  文件名。(node --debug现在已经不推荐使用,改成--inspect了)

nodeJS教程(二)、nodejs调试

chrome浏览器打开服务器url后,打开控制台。点击控制台的nodejs图标,就可以打开调试窗口。

nodeJS教程(二)、nodejs调试

或者输入chrome://inspect/#devices,在打开的页面中,找到Remote Target下面的内容:

nodeJS教程(二)、nodejs调试

调试效果如下:

nodeJS教程(二)、nodejs调试