最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

Node.js入門教程

來源:懂視網(wǎng) 責編:小采 時間:2020-11-27 20:13:58
文檔

Node.js入門教程

Node.js入門教程:Node.js 是一個基于Chrome JavaScript 運行時建立的一個平臺。接下來通過本文給大家分享node.js 入門前傳,感興趣的朋友一起看看吧1.什么是NodeJS簡單的說 Node.js 就是運行在服務端的 JavaScript。Node.js 是一個基于Chrome JavaScr
推薦度:
導讀Node.js入門教程:Node.js 是一個基于Chrome JavaScript 運行時建立的一個平臺。接下來通過本文給大家分享node.js 入門前傳,感興趣的朋友一起看看吧1.什么是NodeJS簡單的說 Node.js 就是運行在服務端的 JavaScript。Node.js 是一個基于Chrome JavaScr
Node.js 是一個基于Chrome JavaScript 運行時建立的一個平臺。接下來通過本文給大家分享node.js 入門前傳,感興趣的朋友一起看看吧

1.什么是NodeJS

簡單的說 Node.js 就是運行在服務端的 JavaScript。

Node.js 是一個基于Chrome JavaScript 運行時建立的一個平臺。

Node.js是一個事件驅動I/O服務端JavaScript環(huán)境,基于Google的V8引擎(Google的Chrome瀏覽器使用的JavaScript執(zhí)行環(huán)境),

V8引擎執(zhí)行Javascript的速度非???,性能非常好。

2.為什么選擇NodeJS

如果你是一個前端程序員,你不懂得像PHP、Python或Ruby等動態(tài)編程語言,然后你想創(chuàng)建自己的服務,那么Node.js是一個非常好的選擇。

Node.js 是運行在服務端的 JavaScript,如果你熟悉Javascript,那么你將會很容易的學會Node.js。

當然,如果你是后端程序員,想部署一些高性能的服務,那么學習Node.js也是一個非常好的選擇。

3.NodeJS的特點

我們先來看看NodeJS官網(wǎng)上的介紹:

  Node.js is a platform built on Chrome's JavaScript runtime for easily building fast, scalable network applications. Node.js uses an event-driven, non-blocking I/O model that makes it lightweight and efficient, perfect for data-intensive real-time applications that run across distributed devices.

  其特點為:

  1. 它是一個Javascript運行環(huán)境

  2. 依賴于Chrome V8引擎進行代碼解釋

  3. 事件驅動

  4. 非阻塞I/O

  5. 輕量、可伸縮,適于實時數(shù)據(jù)交互應用

  6. 單進程,單線程

異步、事件驅動模型

我們同樣是要發(fā)起請求,等待服務器端響應;但是與銀行例子不同的是,這次我們點完餐后拿到了一個號碼,

  拿到號碼,我們往往會在位置上等待,而在我們后面的請求會繼續(xù)得到處理,同樣是拿了一個號碼然后到一旁等待,接待員能一直進行處理。

  等到飯菜做號了,會喊號碼,我們拿到了自己的飯菜,進行后續(xù)的處理(吃飯)

  這個喊號碼的動作在NodeJS中叫做回調(diào)(Callback),能在事件(燒菜,I/O)處理完成后繼續(xù)執(zhí)行后面的邏輯(吃飯),

  這體現(xiàn)了NodeJS的顯著特點,異步機制、事件驅動

  整個過程沒有阻塞新用戶的連接(點餐),也不需要維護已經(jīng)點餐的用戶與廚師的連接

Node.Js使用事件驅動模型,當web server接收到請求,就把它關閉然后進行處理,然后去服務下一個web請求。當這個請求完成,它被放回處理隊列,當?shù)竭_隊列開頭,這個結果被返回給用戶。這個模型非常高效可擴展性非常強,因為webserver一直接受請求而不等待任何讀寫操作。(這也被稱之為非阻塞式IO或者事件驅動IO)

  基于這樣的機制,理論上陸續(xù)有用戶請求連接,NodeJS都可以進行響應,因此NodeJS能支持比Java、PHP程序更高的并發(fā)量

  雖然維護事件隊列也需要成本,再由于NodeJS是單線程,事件隊列越長,得到響應的時間就越長,并發(fā)量上去還是會力不從心

  總結一下NodeJS是怎么解決并發(fā)連接這個問題的:

  更改連接到服務器的方式,每個連接發(fā)射(emit)一個在NodeJS引擎進程中運行的事件(Event),放進事件隊列當中,

  而不是為每個連接生成一個新的OS線程(并為其分配一些配套內(nèi)存)

I/O阻塞

NodeJS解決的另外一個問題是I/O阻塞,看看這樣的業(yè)務場景:需要從多個數(shù)據(jù)源拉取數(shù)據(jù),然后進行處理

  (1)串行獲取數(shù)據(jù),這是我們一般的解決方案,以PHP為例

  假如獲取profile和timeline操作各需要1S,那么串行獲取就需要2S

 ?。?)NodeJS非阻塞I/O,發(fā)射/監(jiān)聽事件來控制執(zhí)行過程

  NodeJS遇到I/O事件會創(chuàng)建一個線程去執(zhí)行,然后主線程會繼續(xù)往下執(zhí)行的,

  因此,拿profile的動作觸發(fā)一個I/O事件,馬上就會執(zhí)行拿timeline的動作,

  兩個動作并行執(zhí)行,假如各需要1S,那么總的時間也就是1S

  它們的I/O操作執(zhí)行完成后,發(fā)射一個事件,profile和timeline,

  事件代理接收后繼續(xù)往下執(zhí)行后面的邏輯,這就是NodeJS非阻塞I/O的特點

  總結一下:

  Java、PHP也有辦法實現(xiàn)并行請求(子線程),但NodeJS通過回調(diào)函數(shù)(Callback)和異步機制會做得很自然

4. NodeJS的優(yōu)缺點

  優(yōu)點:

  1. 高并發(fā)(最重要的優(yōu)點)

  2. 適合I/O密集型應用

  缺點:

  1. 不適合CPU密集型應用;CPU密集型應用給Node帶來的挑戰(zhàn)主要是:由于JavaScript單線程的原因,如果有長時間運行的計算(比如大循環(huán)),將會導致CPU時間片不能釋放,使得后續(xù)I/O無法發(fā)起;

    解決方案:分解大型運算任務為多個小任務,使得運算能夠適時釋放,不阻塞I/O調(diào)用的發(fā)起;

  2. 只支持單核CPU,不能充分利用CPU

  3. 可靠性低,一旦代碼某個環(huán)節(jié)崩潰,整個系統(tǒng)都崩潰

    原因:單進程,單線程

    解決方案:(1)Nnigx反向代理,負載均衡,開多個進程,綁定多個端口;

         (2)開多個進程監(jiān)聽同一個端口,使用cluster模塊;

  4. 開源組件庫質(zhì)量參差不齊,更新快,向下不兼容

  5. Debug不方便,錯誤沒有stack trace

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

Node.js入門教程

Node.js入門教程:Node.js 是一個基于Chrome JavaScript 運行時建立的一個平臺。接下來通過本文給大家分享node.js 入門前傳,感興趣的朋友一起看看吧1.什么是NodeJS簡單的說 Node.js 就是運行在服務端的 JavaScript。Node.js 是一個基于Chrome JavaScr
推薦度:
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top