溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何調(diào)試nodejs程序

發(fā)布時間:2021-05-24 15:09:15 來源:億速云 閱讀:212 作者:Leah 欄目:web開發(fā)

如何調(diào)試nodejs程序?相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。

開啟nodejs的調(diào)試

還記得之前我們講到的koa程序嗎?本文將會以一個簡單的koa服務(wù)端程序為例,來展開nodejs的調(diào)試。

先看下一個簡單的koa服務(wù)app.js:

const Koa = require('koa');
const app = module.exports = new Koa();

app.use(async function(ctx) {
  ctx.body = 'Hello World';
});

if (!module.parent) app.listen(3000);

上面的程序開啟了3000端口,建立了一個http服務(wù)。每次請求的時候,都會返回hello World,非常的簡單。

要想運行上面的程序,我們需要執(zhí)行node app.js。 這會執(zhí)行app.js但是并不會開啟調(diào)試功能?!就扑]學(xué)習(xí):《nodejs 教程》】

怎么進(jìn)行調(diào)試呢?

我們需要加上 --inspect 參數(shù):

node --inspect app.js

上面的代碼將會開啟nodejs的調(diào)試功能。

我們看下輸出結(jié)果:

Debugger listening on ws://127.0.0.1:9229/88c23ae3-9081-41cd-98b0-d0f7ebceab5a
For help, see: https://nodejs.org/en/docs/inspector

結(jié)果告訴了我們兩件事情,第一件事情就是debugger監(jiān)聽的端口。默認(rèn)情況下將會開啟127.0.0.1的9229端口。并且分配了一個唯一的UUID以供區(qū)分。

第二件事情就是告訴我們nodejs使用的調(diào)試器是Inspector。

Inspector是nodejs 8之后引入的,如果是在nodejs 7之前,那么使用的是legacy debugger。

調(diào)試的安全性

如果debugger連接到了nodejs運行環(huán)境中,如果有惡意攻擊者的話,這個惡意攻擊者可以在nodejs環(huán)境中運行任意代碼。這會給我們的程序帶來很大的安全隱患。

所以我們一定要注意調(diào)試的安全性。一般來說,我們不建議進(jìn)行遠(yuǎn)程調(diào)試。

默認(rèn)情況下 --inspect 綁定的是127.0.0.1,這樣就只允許本地程序訪問。并且任何本地運行的程序都有權(quán)限進(jìn)行該程序的調(diào)試。

如果我們真的想將debug程序暴露給外部程序的話,那么可以指明本機(jī)的外網(wǎng)IP地址或者0.0.0.0(表示任何地址,無限制),這樣遠(yuǎn)程機(jī)子就可以進(jìn)行遠(yuǎn)程調(diào)試了。

如果我們想進(jìn)行安全的remote debug該怎么處理呢?

首先,我們要開啟本地的debug:

node --inspect app.js

然后我們可以搭建一個ssh隧道,將本地的9221端口映射到遠(yuǎn)程服務(wù)器的9229端口:

ssh -L 9221:localhost:9229 user@remote.example.com

這樣我們就可以通過連接本地的9221端口,進(jìn)行遠(yuǎn)程調(diào)試了。

使用WebStorm進(jìn)行nodejs調(diào)試

JetBrains出品的WebStorm可謂是開發(fā)nodejs的利器,WebStorm自帶有debug選項,如果開啟該選項,則會在后臺開啟 --inspect:

如何調(diào)試nodejs程序

使用WebStorm來進(jìn)行調(diào)試和使用IDEA來進(jìn)行java程序調(diào)試類似,這里就不多介紹了。

使用Chrome devTools進(jìn)行調(diào)試

使用Chrome devTools進(jìn)行調(diào)試的前提是我們已經(jīng)開啟了 --inspect模式。

在chrome中輸入chrome://inspect:

如何調(diào)試nodejs程序

我們可看到chrome inspect的界面,如果你本地已經(jīng)有開啟inspect的nodejs程序的話,在Remote Target中就可以直接看到。

選中你要調(diào)試的target,點擊inspect,即可開啟Chrome devTools調(diào)試工具:

如何調(diào)試nodejs程序

你可以對程序進(jìn)行profile,也可以進(jìn)行調(diào)試。

這里我們關(guān)注的是調(diào)試,所以轉(zhuǎn)到source一欄,添加你要調(diào)試的程序的源代碼:

如何調(diào)試nodejs程序

加入斷點即可開始調(diào)試了。和在chrome中調(diào)試web端的js是一樣的。

使用node-inspect來進(jìn)行調(diào)試

其實nodejs有一個自帶的調(diào)試工具,叫做node-inspect,這是一個cli的調(diào)試工具。我們看一下怎么使用。

我們直接使用:

node inspect app.js

< Debugger listening on ws://127.0.0.1:9229/f1c64736-47a1-42c9-9e9e-f2665073d3eb
< For help, see: https://nodejs.org/en/docs/inspector
< Debugger attached.
Break on start in app.js:1
> 1 const Koa = require('koa');
  2 const app = module.exports = new Koa();
  3 
debug>

node inspect 做了兩件事情,第一件事情就是生成子程序去運行node --inspect app.js,第二件事情就是在主程序中運行CLI調(diào)試窗口。

這個CLI調(diào)試程序為我們提供了一些非常有用的命令:

  1. Stepping

  • cont, c: 繼續(xù)執(zhí)行

  • next, n: Step到下一步

  • step, s: Step in

  • out, o: Step out

  • pause: 暫停運行的代碼

  1. Breakpoints

  • setBreakpoint(), sb(): 在當(dāng)前行設(shè)置斷點

  • setBreakpoint(line), sb(line): 在指定的行設(shè)置斷點

  • setBreakpoint(‘fn()’), sb(…): 在指定的function中設(shè)置斷點

  • setBreakpoint(‘script.js’, 1), sb(…): 在指定的腳本文件中設(shè)置斷點

  • clearBreakpoint(‘script.js’, 1), cb(…): 從文件中清除斷點

  1. Information

  • backtrace, bt: 打印當(dāng)前execution frame的backtrace信息

  • list(5): 列出源代碼前后的5行

  • watch(expr): 添加監(jiān)聽表達(dá)式

  • unwatch(expr): 刪除監(jiān)聽表達(dá)式

  • watchers: 列出所有的watchers

  • repl: 打開repl表達(dá)式

  • exec expr: 執(zhí)行表達(dá)式

通過上面的命令,我們可以在CLI中進(jìn)行比較復(fù)雜的調(diào)試活動。

看完上述內(nèi)容,你們掌握如何調(diào)試nodejs程序的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI