您的位置:首页 > Web前端 > Node.js

Node.js调试大法 — v8_inspector

2017-05-21 11:46 741 查看

Node.js 调试基本原理

Node.js 提供了强大的
Debugger
模块,使用方式如下:



使用
debug
模式时,Node.js 会启动
Debugger
模块,然后通过监听默认 5858 端口将命令行的输入传送到内建调试模块以达到调试的目的。

同时支持
--debug
--debug-brk
参数。这两个参数只会启动
Debugger
监听模式,不会进入命令行调试模式,而且前者会运行完所有代码,通常可用于事件调试,后者会在进入时中断,方便从头开始调试。

进入
Debugger
监听模式后,可以通过这两种方式连接调试:

node debug <URI> # 通过 URI 连接调试,如 node debug localhost:5858
node debug -p <pid> # 通过 PID 链接调试

命令行调试几乎支持所有调试的功能:断点、单步、步入、步出、变量查看等等。详细说明可参见官方文档

所以无论是IDE 调试工具还是
node-inspector
都是基于Node.js的
Debugger
模块进行调试的。

Chrome DevTools与Node.js Debugger结合

Node.js
命令行调试因为缺少调试界面,因此使用的人相对比较少。于是就诞生了
node-inspector
。 它所做的就是让用户可以使用
DevTools UI
去使用原生的
Debugger
,使用起来也比较方便

安装
node-inspector

npm install -g node-inspector


开启
node-inspector
服务
node-inspector
# node-inspector & ### Running in background


debug
模式启动程序
node --debug test.js
# node --debug-brk test.js # Pause your script on the first line

然后就可以直接用浏览器打开
http://127.0.0.1:8080/?port=5858
进行调试了。
Node.js
原生
Debugger
模块使用的是V8-Debug Protcol,而且
DevTools
使用Chrome
Debugging Protcol。所以
node-inspector
在其中起到了翻译和转达的作用。



v8_inspector
诞生

今年5月份,谷歌工程师
ofrobots 提交了一个Add v8_inspector support的PR。同时在5月份的

DevTools Google I/O talk 有提到此功能。

就是说
v8_inspector
可以让
DevTools
直接连接
Node.js
Debugger
进行调试。

现如今,新版本的Chrome浏览器和新版本的
Node.js
支持通过一个新的调试协议能互相直接通讯了,就不再需要
node-inspector
了。



安装新版本

Node.js 6.3+

可以从官网安装,目前给官网给到的最新版本是v6.7.0
Chrome 55+

最新版本的 Chrome 叫
Canary,安装这个版本时不用担心会覆盖老版本的Chrome,会生成另外一个图标。


启用
inspect
调试模式

下载好
Chrome Canary
后,打开
chrome://flags/#enable-devtools-experiments

启用开发者工具实验性功能



重启Chrome
打开开发者工具 -> 设置 -> Experiments,按
SHIFT
键6次,显示隐藏选项后勾选
Node debugging




使用
inspect
调试

使用
--inspect
参数就可以使用最新的调试功能:



Canary
中打开链接即可调试。

使用中的问题

在用
v6.7.0
测试时发现一直在报错
Assertion '(inspector->http_parsing_state) == (nullptr)' failed.




发现很多人有出现过这个问题,参见这里

这是一个已经修复的bug,但是
v6.7.0
中没有包含,解决方案就是安装
v7.x
版本,两种安装方式:

下载源码安装
# Install windows-build-tools
npm install --global --production windows-build-tools

# Download source code
git clone https://github.com/nodejs/node.git cd node
git checkout remotes/origin/v7.x

# Build
# vcbuild nosign x64 # 64-bit build on windows
vcbuild nosign

下载
896a
v7.0.0-nightly 安装包安装
使用新版本彻底解决了这个问题。

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: