Node.js源碼學(xué)習(xí)(1) 使用cLion調(diào)試node.js源碼

原文地址:http://hiihl.com/articles/2018/1/15/learnnode1.md
本人近期在學(xué)習(xí)Node.js源碼,并將會把學(xué)習(xí)過程、心得形成筆記香府。

環(huán)境準(zhǔn)備

  • 操作系統(tǒng): macOS
  • IDE: cLion
  • 源碼路徑: Node Master

本地編譯

node.js是用C++寫的平斩,所以編譯有以下步驟:

  • ./configure 配置。軟件裝到哪里瞭稼、什么參數(shù)忽洛、什么os、裝什么東西环肘,全都是configure來確定的
  • make 編譯欲虚。make會讀取makefile的配置,進(jìn)行編譯悔雹,生成可執(zhí)行文件
  • make install 安裝复哆。make install 會根據(jù)設(shè)定好的路徑欣喧,把軟件安裝到系統(tǒng)中

首先是配置

進(jìn)入到node目錄后,執(zhí)行./configure --debug梯找,注意后面的--debug续誉,一開始我沒有加的試后發(fā)現(xiàn)斷點(diǎn)進(jìn)不去;
執(zhí)行完以后會生成以下文件:

|____cctest.target.mk
|____gyp-mac-tool
|____Makefile
|____mkssldef.target.mk
|____node.target.mk
|____node_dtrace_header.target.mk
|____node_dtrace_provider.target.mk
|____node_dtrace_ustack.target.mk
|____node_etw.target.mk
|____node_js2c.host.mk
|____node_perfctr.target.mk
|____specialize_node_d.target.mk
|____v8_inspector_compress_protocol_json.host.mk

這些文件應(yīng)該是make編譯時需要的一些參數(shù)配置

之后執(zhí)行make編譯初肉,在這之前酷鸦,我看到了Makefile中有這樣一段注釋(搜debug看到的)

# BUILDTYPE=Debug builds both release and debug builds. If you want to compile
# just the debug build, run `make -C out BUILDTYPE=Debug` instead.

從這段注釋理解,如果我們運(yùn)行make -C out BUILDTYPE=Debug則不會編譯release代碼牙咏,由于我們是本地學(xué)習(xí)使用臼隔,所以我使用
make -C out BUILDTYPE=Debug -j 4編譯,其中-j時編譯使用的進(jìn)程數(shù)妄壶,用于加快編譯摔握。
編譯過程時間比較久,編譯完以后可以看到多了一個out目錄丁寄,out/Debug目錄下有個可執(zhí)行的文件node氨淌,這就是我們本地編譯出來的node啦。

第三步make install是安裝時需要伊磺,此處可以忽略盛正。

導(dǎo)入工程

打開IDE cLion,并導(dǎo)入本地的node項(xiàng)目屑埋,打開Run/Debug配置調(diào)試信息


2018-1-15-learnnode1.jpg

參照上圖配置:

  • 選擇Executable為前面編譯出來的out/Debug/node;
  • Before launch中有一個build豪筝,我們要把它刪掉,否則每次都會重新編譯;
  • Work directory選擇要運(yùn)行的js代碼目錄;
  • Program arguments即為要運(yùn)行的js代碼摘能。

ok续崖,然后找到node_main.cc,在main方法中打斷點(diǎn)团搞,debug運(yùn)行

2018-1-15-learnnode2.jpg

如圖所示严望,我們成功進(jìn)入了斷點(diǎn)。

同時調(diào)試js及node源碼

如果逻恐,我們想要同時調(diào)試js代碼及node.js源碼像吻,該如何配置呢?
回想我們使用webpack debug代碼時控制臺上會打印node --inspect-brk=49469 /xxx.js梢莽,node版本<8時打印--debug --debug-brk=49469萧豆,
其中這49469就是node.js的調(diào)試窗口,所以我們在調(diào)試node.js源碼時昏名,Program arguments可以這樣配置--inspect-brk=49469 ./test.js涮雷,
然后再啟動一個Node.js Remote Debug (webStorm中)或 Attach to Node.js/Chrome (cLion中),端口號配置為49469轻局,即可同時調(diào)試js

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末洪鸭,一起剝皮案震驚了整個濱河市样刷,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌览爵,老刑警劉巖置鼻,帶你破解...
    沈念sama閱讀 218,755評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異蜓竹,居然都是意外死亡箕母,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評論 3 395
  • 文/潘曉璐 我一進(jìn)店門俱济,熙熙樓的掌柜王于貴愁眉苦臉地迎上來嘶是,“玉大人,你說我怎么就攤上這事蛛碌∧衾” “怎么了?”我有些...
    開封第一講書人閱讀 165,138評論 0 355
  • 文/不壞的土叔 我叫張陵蔚携,是天一觀的道長希太。 經(jīng)常有香客問我,道長酝蜒,這世上最難降的妖魔是什么誊辉? 我笑而不...
    開封第一講書人閱讀 58,791評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮秕硝,結(jié)果婚禮上芥映,老公的妹妹穿的比我還像新娘洲尊。我一直安慰自己远豺,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,794評論 6 392
  • 文/花漫 我一把揭開白布坞嘀。 她就那樣靜靜地躺著躯护,像睡著了一般。 火紅的嫁衣襯著肌膚如雪丽涩。 梳的紋絲不亂的頭發(fā)上棺滞,一...
    開封第一講書人閱讀 51,631評論 1 305
  • 那天,我揣著相機(jī)與錄音矢渊,去河邊找鬼继准。 笑死,一個胖子當(dāng)著我的面吹牛矮男,可吹牛的內(nèi)容都是我干的移必。 我是一名探鬼主播,決...
    沈念sama閱讀 40,362評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼毡鉴,長吁一口氣:“原來是場噩夢啊……” “哼崔泵!你這毒婦竟也來了秒赤?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,264評論 0 276
  • 序言:老撾萬榮一對情侶失蹤憎瘸,失蹤者是張志新(化名)和其女友劉穎入篮,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體幌甘,經(jīng)...
    沈念sama閱讀 45,724評論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡潮售,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了锅风。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片饲做。...
    茶點(diǎn)故事閱讀 40,040評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖遏弱,靈堂內(nèi)的尸體忽然破棺而出盆均,到底是詐尸還是另有隱情,我是刑警寧澤漱逸,帶...
    沈念sama閱讀 35,742評論 5 346
  • 正文 年R本政府宣布泪姨,位于F島的核電站,受9級特大地震影響饰抒,放射性物質(zhì)發(fā)生泄漏肮砾。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,364評論 3 330
  • 文/蒙蒙 一袋坑、第九天 我趴在偏房一處隱蔽的房頂上張望仗处。 院中可真熱鬧,春花似錦枣宫、人聲如沸婆誓。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,944評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽洋幻。三九已至,卻和暖如春翅娶,著一層夾襖步出監(jiān)牢的瞬間文留,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,060評論 1 270
  • 我被黑心中介騙來泰國打工竭沫, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留燥翅,地道東北人。 一個月前我還...
    沈念sama閱讀 48,247評論 3 371
  • 正文 我出身青樓蜕提,卻偏偏與公主長得像森书,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,979評論 2 355