亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

Nodejs libuv運行原理詳解

2024-05-06 16:54:24
字體:
來源:轉載
供稿:網友

前言

這應該是Nodejs的運行原理的第7篇分享,這篇過后,短時間內不會再分享Nodejs的運行原理,會停更一段時間,PS:不是不更,而是會開挖新的坑,最近有在研究RPG Maker MV,區塊鏈,云計算,可能會更新一些相關文章,或者相關教學。

回到正題,異步編程的難點在于請求與響應不是按順序發生的。以http server 為例,異步編程賦予了server 高并發的品質,而且他可以以很小的資源代價,不斷地接受和處理請求。但是快速處理請求不表示快速地返回請求=>高并發不等同于快速反饋。

在Nodejs中,libuv則為異步編程的實現提供了可能。libuv為builtin modules 提供了API,這些API用來支撐請求和數據的返回的異步處理方式。

這一篇分享,我們主要討論libuv的運行原理,從兩個角度出發:

1) libuv的架構

2) 案例,從細節的角度看libuv是如何對待不同I/O請求,按照不同的方式來完成異步請求和數據返回的。

Libuv的架構

Nodejs,libuv

從左往右可分為兩部分,Network I/O的相關請求,另一部分File I/O,DNS Ops和User Code組成。

Nodejs,libuv

上圖展示了libuv細節的流程,圖中代碼很簡單,包括2個部分:

1. server.listen()是用來創建TCP server時,通常放在最后一步執行的代碼。主要指定服務器工作的端口以及回調函數。

2. fs.open()是用異步的方式打開一個文件。

選擇兩個示例很簡單,因為libuv架構圖可視:libuv對 Network I/O和 File I/O采用不同的機制。

上圖右半部分,主要分成兩個部分:

1. 主線程:主線程也是node啟動時執行的現成。node啟動時,會完成一系列的初始化動作,啟動V8 engine,進入下一個循環。

2. 線程池:線程池的數量可以通過環境變量UV_THREADPOOL_SIZE配置,最大不超過128個,默認為4個。

Network I/O

V8 engine執行從server.listen() 開始,調用builtin module Tcp_wrap 的過程。

在創建TCP鏈接的過程中,libuv直接參與Tcp_wrap.cc函數中的 TCPWrap::listen() 調用uv_listen()開始到執行uv_io_start()結束。看起來很短暫的過程,其實是類似linux kernel的中斷處理機制。

uv_io_start()負載將handle插入到處理的water queue中。這樣的好處是請求能夠立即得到處理。中斷處理機制里面的下半部分與數據處理操作相似,交由主線程去完成處理。

Nodejs,libuv

 

代碼邏輯很簡單,查看loop中是否包含handle,如果有遍歷default loop。

Nodejs,libuv

File I/O

這里我們研究一下 File I/O。

同Network I/O一樣,我們的應用所依賴的fs模塊,后面有一個builtin module Node_file.cc作為支撐。 Node_file.cc包含了各種我們常用的文件操作的接口,例如open, read, write, chmod,chown等。但同時,它們都支持異步模式。 我們通過Node_file.cc中的Open()函數來研究一下具體的實現細節。

如果你用類似source insight之類的代碼閱讀工具跟蹤一下代碼調用順序,會很容易發現對于異步模式,Open()函數會在一系列輔助操作之后,進入函數uv_fs_open(),并且傳入了一個FSReqWrap的對象。

FSReqWrap(),從名字可以看得出來,這是一個wrap,且是與FS相關的請求。也就是說,它基于某一個現成的機制來實現與FS相關的請求操作。這個現成的機制就是ReqWrap。好吧,它也是個wrap。乘你還沒瘋的時候,看一下圖6吧。這里完整展示了FSReqWrap類繼承關系。

Nodejs,libuv

除了FSReqWrap,還有其它Wrap,例如PipeConnectWrap,TCPConnectWrap等等。每個Wrap均為一種請求類型服務。 但是這些wrap,都是node自身的行為,而與libuv相關的是什么呢?上圖中表示出了FSReqWrap關鍵的數據結構 uv_fs_s req__。

讓我們把目光回到uv_fs_open()。在調用這個函數時, req__作為其一個重要的參數被傳遞進去。而在uv_fs_open()內部,req__則被添加到work queue的末尾中去。圖3 thread pool中的thread會去領取這些request進行處理。 每個request很像一個粘貼板,它將event loop, work queue,每個請求的處理函數(work()),以及請求結束處理函數(done())綁定在一起。綁定的操作在uv__work_submit()中完成。 例如對于這里的req__,綁定在它身上的work()為uv__fs_work(), done()為uv__fs_done()。

這里有一個比較有意思的問題值得額外看一下。我們的thread pool是在什么時候建立的呢?

答案是:在第一次異步調用uv__work_submit()時。

每個thead的入口函數是 Threadpool.c中的worker()。工作邏輯比較簡單,依次取出work queue中的請求,執行綁定在該請求上的work()函數。 前面我們提到的綁定在請求上的done()函數在哪里執行呢?這也是一個比較有意思的操作。libuv通過uv_async_send()通知event loop去執行相應的callback函數,也即我們綁定在request上的done()函數。uv__work_done()用于完成這樣的操作。

uv_async_send()與主線程之間通過PIPE通信。

我在這一小節以一個FSReqWrap以及Open()函數為例,描述了libuv處理這種File I/O請求時所涉及的各種操作:

建立thread pool(只建立一次) 在每個請求req__上綁定與其相關的event loop, work queue, work(), done() thread worker()用來處理work queue里面的每個請求,并執行work() 通過uv_async_send()通知event loop執行done()

以上就是關于本次相關的知識點內容,感謝大家對VeVb武林網的支持。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品有码在线| 亚洲国产欧美一区二区三区同亚洲| 亚洲精品国产精品久久清纯直播| 亚洲人成电影在线播放| 日韩在线资源网| 国产精品九九九| 午夜精品久久久久久久久久久久久| 国产精品69精品一区二区三区| 日韩最新av在线| 亚洲午夜精品久久久久久久久久久久| 亚洲大胆美女视频| 日韩高清不卡av| 久久久精品亚洲| 日韩av免费观影| 人人爽久久涩噜噜噜网站| 中文精品99久久国产香蕉| 免费97视频在线精品国自产拍| 91欧美精品成人综合在线观看| 国产亚洲欧洲黄色| 色先锋久久影院av| 色狠狠av一区二区三区香蕉蜜桃| 国产精品丝袜久久久久久高清| 成人免费福利视频| 亚洲欧美成人在线| 91国产精品91| 亚洲第一男人av| 日韩av在线免费观看| 日韩中文字幕国产| 欧美尺度大的性做爰视频| 亚洲精品国精品久久99热| 欧美夜福利tv在线| 国产午夜精品美女视频明星a级| 成人午夜在线视频一区| 国产aaa精品| 久久视频精品在线| 亚洲欧美日韩在线高清直播| 国产91精品不卡视频| 2018日韩中文字幕| 久久精品电影网站| 精品高清一区二区三区| 亚洲成人黄色网| 青草青草久热精品视频在线观看| 欧美色道久久88综合亚洲精品| 亚洲a一级视频| 国产精品美女免费| 疯狂做受xxxx高潮欧美日本| 免费91在线视频| 国产精品va在线播放| 久久精品国产免费观看| 欧美中在线观看| 自拍视频国产精品| 亚洲欧美日韩精品久久| 欧美精品在线免费播放| 97国产精品人人爽人人做| 欧美日韩国产成人在线观看| 国产精品第一第二| 久久国产一区二区三区| 亚洲已满18点击进入在线看片| 成人黄色免费看| 亚洲天堂成人在线视频| 91精品久久久久久久久中文字幕| 国产精品中文字幕久久久| 亚洲精品免费网站| 欧美专区国产专区| 久久精品视频在线观看| 日韩一中文字幕| 中国日韩欧美久久久久久久久| 91精品国产网站| 国产z一区二区三区| 亚洲一区二区精品| 亚洲精品日韩丝袜精品| 亲爱的老师9免费观看全集电视剧| 亚洲精品在线不卡| 国产欧美va欧美va香蕉在线| 国产视频精品在线| 欧美成人免费全部观看天天性色| 精品国产91久久久久久老师| 国产91免费看片| 日韩美女激情视频| 日韩av一区二区在线| 国产成人精品免费久久久久| 久久久99久久精品女同性| 成人国产精品一区| 高跟丝袜欧美一区| 亚洲天堂av在线免费观看| 97精品在线观看| 45www国产精品网站| 久久视频在线播放| 亚洲成人国产精品| 日韩一区二区在线视频| 亚洲人成伊人成综合网久久久| 欧美一级片在线播放| 97精品伊人久久久大香线蕉| 国产精品久久久久久av福利软件| 97**国产露脸精品国产| 欧美极品少妇全裸体| 性欧美激情精品| 日韩中文字幕网| 最近中文字幕mv在线一区二区三区四区| 91免费在线视频网站| 日韩成人xxxx| 欧美孕妇孕交黑巨大网站| 久久久精品一区二区| 国产精品免费视频xxxx| 色偷偷av一区二区三区| 性欧美长视频免费观看不卡| 亚洲激情视频网| 成人av番号网| 裸体女人亚洲精品一区| 欧美最猛黑人xxxx黑人猛叫黄| 精品久久久久久中文字幕| 成人一区二区电影| 欧美另类极品videosbest最新版本| 亚洲欧美日韩天堂| 国产亚洲成av人片在线观看桃| 国产日韩精品一区二区| 精品国产一区二区三区在线观看| 精品国产欧美一区二区三区成人| 美女国内精品自产拍在线播放| 成人网在线视频| 黄色精品一区二区| 成人黄色生活片| 日韩精品电影网| 色噜噜狠狠狠综合曰曰曰88av| 亚洲情综合五月天| 91在线观看免费网站| 国产精品96久久久久久又黄又硬| 欧美精品videosex性欧美| 国产成人亚洲精品| 欧美精品久久久久久久久| 亚洲自拍偷拍色片视频| 亚洲另类图片色| 国产精品一区二区久久久| 欧美性一区二区三区| 国产精品入口免费视频一| 欧美激情a∨在线视频播放| 国产一区二区三区视频免费| 91精品国产自产在线| 久久不射电影网| 97在线视频一区| 国产丝袜精品第一页| 91精品久久久久久久久久久久久久| 国产精品igao视频| 亚洲精品久久7777777| 国产亚洲激情视频在线| 亚洲精品福利在线观看| 欧洲亚洲免费在线| 国产精品自产拍在线观看| 日韩中文字幕在线| 成人黄色av播放免费| 69av视频在线播放| 日本乱人伦a精品| 最近2019年好看中文字幕视频| 欧美激情极品视频| 欧美日韩精品二区| 日韩国产激情在线| 亚洲成avwww人| 欧美中文字幕在线| 91精品视频在线免费观看| 中文字幕亚洲在线| 欧美老女人www| 欧美另类精品xxxx孕妇| 九九九热精品免费视频观看网站| 日韩电影在线观看免费|