Node.js調(diào)試技術(shù)總結(jié)分享
前言
眾所周知調(diào)試技術(shù)與開發(fā)技術(shù)構(gòu)成了軟件開發(fā)的基石。目前Nodejs作為新型的Web Server開發(fā)棧倍受開發(fā)者關(guān)注??偟膩碚fNodejs的應(yīng)用程序主要有兩部分:JavaScript編寫的js模塊和C語言編譯的二進制模塊。
這里主要介紹三種avaScript模塊的調(diào)試方法:基于Nodejs內(nèi)建的調(diào)試器,基于V8調(diào)試插件和基于Chrome瀏覽器的調(diào)試器。
以下所有的操作都將基于如下代碼(example.js):
var http = require('http');
var url = require('url');
http.createServer(function (req, res) {
var path = url.parse(req.url).pathname;
res.writeHead(200, {'Content-Type': 'text/plain'});
res.end(path);
}).listen(1337, "127.0.0.1");
console.log('Server running at http://127.0.0.1:1337/');
一. 基于Nodejs內(nèi)建的調(diào)試器
Nodejs提供了一個內(nèi)建調(diào)試器來幫助開發(fā)者調(diào)試應(yīng)用程序。想要開啟調(diào)試器我們需要在代碼中加入debugger標(biāo)簽,當(dāng)Nodejs執(zhí)行到debugger標(biāo)簽時會自動暫停(debugger標(biāo)簽相當(dāng)于在代碼中開啟一個斷點)。代碼如下:
var path = url.parse(req.url).pathname;
debugger;
res.writeHead(200, {'Content-Type': 'text/plain'});
執(zhí)行命令:node debug example.js 就可以進入調(diào)試模式。

在debug模式下,可以使用內(nèi)建命令如repl去評估變量和表達式的值(如2所示)。我們也可以通過help命令來獲取完整的調(diào)試命令列表。
Commands: run (r), cont (c), next (n), step (s), out (o), backtrace (bt), setBreakpoint (sb), clearBreakpoint (cb), watch, unwatch, watchers, repl, restart, kill, list, scripts, breakpoints, version
二. 基于V8插件的調(diào)試器
Nodejs是基于google V8的引擎上構(gòu)建的,Google為Eclipse提供了一個對應(yīng)的調(diào)試插件。關(guān)于如何在Eclipse中安裝和調(diào)試Nodejs程序就不再重復(fù)描述了,網(wǎng)上已經(jīng)有很多的文章了,唯一要注意的是在默認情況下V8引擎支持的調(diào)試模式是本地模式。如果想要開啟遠程調(diào)試的話,我們需要修改Nodejs中的V8源文件: /deps/v8/src/platform-posix.cc
addr.sin_family = AF_INET; addr.sin_addr.s_addr = htonl(INADDR_LOOPBACK); --> INADDR_ANY addr.sin_port = htons(port);
然后重新編譯Nodejs。
提示:
用插件來調(diào)試nodejs程序,你有時候會遇到什么connect refuse, get version failed等等錯誤。那么請注意你使用的ip的地址, 一般下127.0.0.1的回環(huán)地址是都工作的。如果你使用真實的ip地址,請檢查防火墻設(shè)置。
三. 基于Chrome瀏覽器的調(diào)試器
既然我們可以通過V8的調(diào)試插件來調(diào)試,那是否也可以借用Chrome瀏覽器的JavaScript調(diào)試器來調(diào)試呢?node-inspector模塊提供了這樣一種可能。我們需要先通過npm來安裝node-inspector
npm install -g node-inspector // -g 導(dǎo)入安裝路徑到環(huán)境變量
node-inspector是通過websocket方式來轉(zhuǎn)向debug輸入輸出的。因此,我們在調(diào)試前要先啟動node-inspector來監(jiān)聽Nodejs的debug調(diào)試端口。

默認情況下node-inspector的端口是8080,可以通過參數(shù)--web-port=[port]來設(shè)置端口。在啟動node-inpspector之后,我們可以通過--debug或--debug-brk來啟動nodejs程序。通過在瀏覽器輸入http://[ip address]:8080/debug?port=5858,我們會得到如下的調(diào)試窗口:

這三種方法各自有優(yōu)缺點,我個人比較欣賞node-inspector的方式。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
- vscode調(diào)試node.js的實現(xiàn)方法
- Node.js使用supervisor進行開發(fā)中調(diào)試的方法
- 詳解如何在vscode里面調(diào)試js和node.js的方法步驟
- sublime text配置node.js調(diào)試(圖文教程)
- 詳解使用Visual Studio Code對Node.js進行斷點調(diào)試
- 基于node.js之調(diào)試器詳解
- Node.js利用debug模塊打印出調(diào)試日志的方法
- 利用Chrome DevTools直接調(diào)試Node.js和JavaScript的方法詳解(并行)
- 調(diào)試Node.JS的輔助工具(NodeWatcher)
- Node.js 深度調(diào)試方法解析
相關(guān)文章
node.js中的http.response.removeHeader方法使用說明
這篇文章主要介紹了node.js中的http.response.removeHeader方法使用說明,本文介紹了http.response.removeHeader的方法說明、語法、接收參數(shù)、使用實例和實現(xiàn)源碼,需要的朋友可以參考下2014-12-12
nodejs創(chuàng)建簡易web服務(wù)器與文件讀寫的實例
下面小編就為大家?guī)硪黄猲ode js系列課程-創(chuàng)建簡易web服務(wù)器與文件讀寫的實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-09-09
yarn?install命令報錯warning?package-lock.json?found解決辦法
這篇文章主要給大家介紹了關(guān)于yarn?install命令報錯warning?package-lock.json?found的解決辦法,文中通過圖文將解決的辦法介紹的非常詳細,還分享了更多yarn install遇到的報錯及解決方案,需要的朋友可以參考下2024-02-02
基于nodejs+express4.X實現(xiàn)文件下載的實例代碼
本篇文章主要介紹了詳解nodejs+express4.X的文件下載的實例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07

