面試官:說說你對Node.js 的理解?優(yōu)缺點?應用場景?
本文轉(zhuǎn)載自微信公眾號「JS每日一題」,作者灰灰。轉(zhuǎn)載本文請聯(lián)系JS每日一題公眾號。
一、是什么
Node.js 是一個開源與跨平臺的 JavaScript 運行時環(huán)境
在瀏覽器外運行 V8 JavaScript 引擎(Google Chrome 的內(nèi)核),利用事件驅(qū)動、非阻塞和異步輸入輸出模型等技術(shù)提高性能
可以理解為 Node.js 就是一個服務器端的、非阻塞式I/O的、事件驅(qū)動的JavaScript運行環(huán)境
非阻塞異步
Nodejs采用了非阻塞型I/O機制,在做I/O操作的時候不會造成任何的阻塞,當完成之后,以時間的形式通知執(zhí)行操作
例如在執(zhí)行了訪問數(shù)據(jù)庫的代碼之后,將立即轉(zhuǎn)而執(zhí)行其后面的代碼,把數(shù)據(jù)庫返回結(jié)果的處理代碼放在回調(diào)函數(shù)中,從而提高了程序的執(zhí)行效率
事件驅(qū)動
事件驅(qū)動就是當進來一個新的請求的時,請求將會被壓入一個事件隊列中,然后通過一個循環(huán)來檢測隊列中的事件狀態(tài)變化,如果檢測到有狀態(tài)變化的事件,那么就執(zhí)行該事件對應的處理代碼,一般都是回調(diào)函數(shù)
比如讀取一個文件,文件讀取完畢后,就會觸發(fā)對應的狀態(tài),然后通過對應的回調(diào)函數(shù)來進行處理
二、優(yōu)缺點
優(yōu)點:
- 處理高并發(fā)場景性能更佳
- 適合I/O密集型應用,指的是應用在運行極限時,CPU占用率仍然比較低,大部分時間是在做 I/O硬盤內(nèi)存讀寫操作
因為Nodejs是單線程,帶來的缺點有:
- 不適合CPU密集型應用
- 只支持單核CPU,不能充分利用CPU
- 可靠性低,一旦代碼某個環(huán)節(jié)崩潰,整個系統(tǒng)都崩潰
三、應用場景
借助Nodejs的特點和弊端,其應用場景分類如下:
- 善于I/O,不善于計算。因為Nodejs是一個單線程,如果計算(同步)太多,則會阻塞這個線程
- 大量并發(fā)的I/O,應用程序內(nèi)部并不需要進行非常復雜的處理
- 與 websocket 配合,開發(fā)長連接的實時交互應用程序
具體場景可以表現(xiàn)為如下:
- 第一大類:用戶表單收集系統(tǒng)、后臺管理系統(tǒng)、實時交互系統(tǒng)、考試系統(tǒng)、聯(lián)網(wǎng)軟件、高并發(fā)量的web應用程序
- 第二大類:基于web、canvas等多人聯(lián)網(wǎng)游戲
- 第三大類:基于web的多人實時聊天客戶端、聊天室、圖文直播
- 第四大類:單頁面瀏覽器應用程序
- 第五大類:操作數(shù)據(jù)庫、為前端和移動端提供基于json的API
其實,Nodejs能實現(xiàn)幾乎一切的應用,只考慮適不適合使用它
參考文獻
http://nodejs.cn/
https://segmentfault.com/a/1190000019854308
https://segmentfault.com/a/1190000005173218