1. 程式人生 > >node.js調試

node.js調試

方便 page lips ktr 上下 ext node 設置斷點 語法

用了幾天node.js感覺很新奇,但是調試問題實在是愁煞人,開始的時候懶的學習調試方法,看看異常內容就可以了,但隨著代碼復雜程度的上升,並不是所有錯誤都是語法錯誤了,不調試搞不定了,只好搜搜資料,學習了一下怎麽調試。

不用每次都重啟服務的supervisor

使用過PHP的同學肯定都清楚,修改了某個腳本文件後,只要刷新頁面服務器就會加載新的內容,但是node.js在第一次引用到某個文件解析後會將其放入內存,下次訪問的時候直接在內存中獲取,以提高效率,但是這對我們開發造成一定困擾,修改了某個module後只能重啟服務器後才能生效,調試起來效率還是很低的。

於是乎node.js中有了supervisor插件幫我們堅實文件改動,自動重啟服務器,supervisor是node.js的一個包,安裝起來很簡單,使用npm的安裝命令就可以,因為我們需要在控制臺運行,所以需要安裝在全局環境中

npm install -g supervisor

這樣我們就可以使用supervisor啟動腳本了

supervisor index

技術分享

當我們對文件做了改動的時候,可以看到控制臺多了三行,服務器已經重啟了

技術分享

原生控制臺調試

node.js本身支持調試,在語句前面加debugger指令就可以添加一個斷點

技術分享
var server=require(‘./server‘),
    router=require(‘./router‘),
    requestHandlers=require(‘./requestHandlers‘);
debugger;
var handle={};
debugger;
handle[‘/‘]=handle[‘/start‘]=requestHandlers.start;
debugger;
handle[‘/upload‘]=requestHandlers.upload;
handle[‘/show‘]=requestHandlers.show;
debugger;
server.start(8080,router.route,handle);
技術分享

在啟動服務的時候添加debug 選項

node debug index.js

技術分享

這時候輸入一些指令就可以單步調試、到斷點監視局部變量等,看個命令圖,很多命令都有其縮寫形式

node.js調試命令
命令 功能
run
執行腳本,在第一行暫停
restart
重新執行腳本
cont, c
繼續執行,直到遇到下一個斷點
next, n
單步執行
step, s

單步執行並進入函數

out, o

從函數中步出

setBreakpoint(), sb()

當前行設置斷點

setBreakpoint(‘f()’), sb(...)
在函數f的第一行設置斷點
setBreakpoint(‘script.js’, 20), sb(...)
在 script.js 的第20行設置斷點
clearBreakpoint, cb(...)
清除所有斷點
backtrace, bt
顯示當前的調用棧
list(5)
顯示當前執行到的前後5行代碼
watch(expr)
把表達式 expr 加入監視列表
unwatch(expr)
把表達式 expr 從監視列表移除
watchers
顯示監視列表中所有的表達式和值
repl
在當前上下文打開即時求值環境
kill
終止當前執行的腳本
scripts
顯示當前已加載的所有腳本
version
顯示v8版本





詳細使用有興趣同學可以自己摸索,我是沒興趣。。。太復雜了,看幾個貼心的

使用Eclipse調試

是的,Eclipse又威武了,連node.js也能調試,在Eclipe官網上下載eclipse,然後 Help->Install New Software->Add

在彈出的窗口添加一個源,名字好記就行,地址是http://chromedevtools.googlecode.com/svn/update/dev/

技術分享

等一會兒後彈出選擇界面,選中第一個

技術分享

一路next到最後finish,下載完成後會提醒重啟Eclipse,完成之後就可以調試node.js了,打開想調試的文件,切換Eclipse到調試視圖,點擊工具欄右邊的小三角,選擇Debug Configuration

技術分享

雙擊 Standard V8 VM 選項創建一個新的配置,填好相應參數

技術分享

通過 --debug-brk選項在控制臺啟動node服務器

node --debug-brk=5858 test.js

點擊Eclipse剛才界面的debug按鈕,就可以像調試Java一樣調試node.js了

技術分享

使用node-inspector調試

大部分node.js應用都是web應用,所以一些基於Chrome的在線調試工具應運而生,最出名的應該就是node-inspector了,這是一個node.js的模塊,安裝、使用相當的方便,首先使用npm把其安裝在全局環境中

npm install -g node-inspector

node-inspector是通過websocket方式來轉向debug輸入輸出的。因此,我們在調試前要先啟動node-inspector來監聽node.js的debug調試端口。默認情況下node-inspector的端口是8080,可以通過參數--web-port=[port]來設置端口。

技術分享

在啟動node-inpspector之後,我們可以通過--debug或--debug-brk來啟動node.js程序。

技術分享

這時候就可以訪問http://127.0.0.1:8888/debug?port=5858 使用瀏覽器調試了,看看界面,不用多說什麽了吧

技術分享

最後

參考:node.js開發指南

PS:個人覺得還是最後一種最方便

node.js調試