異步IO(待修正)

** 操作系統(tǒng)將所有的輸入輸出設(shè)備抽象為文件, 在進(jìn)行I/O操作時(shí)實(shí)際上要先獲取文件描述符, 然后根據(jù)文件描述符進(jìn)行操作。**
** 同步IO 是指:**
** 發(fā)起請(qǐng)求--> 獲取文件描述符 --> 讀取文件 --> 讀取文件結(jié)束并返回 **
** 異步IO 是指: **
** 發(fā)起請(qǐng)求 --> 獲取文件描述符 --> 返回 **
**那么, 如何知道文件是否讀取完成?這時(shí)要使用 輪詢, 即重復(fù)調(diào)用I/O 來確認(rèn)是否完成 **

輪詢

  1. read, 重復(fù)檢查I/O的狀態(tài)
  2. select, 使用1024 長度的數(shù)組來存儲(chǔ)狀態(tài), 通過判斷文件描述符上的事件狀態(tài)
  3. poll, 將select 的數(shù)組換位鏈表。
  4. epoll, Linux 下效率最高的I/O機(jī)制,檢測不到I/O事件時(shí)會(huì)進(jìn)行休眠,直至有事件發(fā)生將其喚醒不浪費(fèi)CPU
  5. iocp , windows 下的 I/O 機(jī)制,也實(shí)現(xiàn)了異步。

**Node 的異步IO 實(shí)際上是用 主線程 +線程池/IOCP 的方式模擬的異步IO, 而且在主線程上仍然是“同步” **
Event Loop 事件循環(huán)如下所示:

Paste_Image.png

  1. 檢查 Event queue 即事件隊(duì)列中是否還有事件
  2. 有事件則取出一個(gè)交給主線程去處理。
  3. 主線程將I/O操作交給線程池中的的某個(gè)線程處理,然后接著處理下一個(gè)事件。
  4. 調(diào)用線程處理事件, 如果處理事件完成,將完成的結(jié)果放回到 Event queue 中。

Node為了進(jìn)行跨平臺(tái),提供了抽象封裝層 --> libuv 進(jìn)行平臺(tái)的判斷, 在Node 編譯的時(shí)候會(huì)進(jìn)行判斷,選擇性的編譯 *nix 或者 Windows 文件。 在 windows 下的異步是調(diào)用了 IOCP 來實(shí)現(xiàn), 在*nix 下是使用了 Node 自帶的線程池實(shí)現(xiàn)。

Paste_Image.png
  1. V8 引擎負(fù)責(zé)解析js 代碼
  2. 解析完成的代碼調(diào)用Node 的API
  3. libuv 負(fù)責(zé)處理 事件循環(huán)和調(diào)用IOCP或者自己的線程池處理I/O 操作, 將結(jié)果返回給 V8 引擎
  4. V8 負(fù)責(zé)將結(jié)果返回給用戶。

參考鏈接:
http://www.ruanyifeng.com/blog/2014/10/event-loop.html
https://vimeo.com/96425312,
樸靈 《深入簡出NodeJs》

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容