亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

Nodejs系列-開篇

??? 2016-11-07 14:52:23 478
????:1.解決什么問題1. 并發(fā)連接舉個(gè)例子,想象一個(gè)場景,我們在銀行排隊(duì)辦理業(yè)務(wù),我們看看下面兩個(gè)模型。(1)系統(tǒng)線程模型:這種模型的問題顯而易見,服務(wù)端只有一個(gè)線程,并發(fā)請(qǐng)求(用戶)到達(dá)只能處理一個(gè),其余的要先等待,這就是阻塞,正在享受服務(wù)的請(qǐng)求阻塞后面的請(qǐng)求了。(2)多線程、線程池模型:這個(gè)模型已經(jīng)比上一個(gè)有所進(jìn)步,它調(diào)節(jié)服務(wù)端線程的數(shù)量來提高對(duì)并發(fā)請(qǐng)求的接收和響應(yīng),但并發(fā)量高的時(shí)候,請(qǐng)求仍然需要

1.解決什么問題

1. 并發(fā)連接

舉個(gè)例子,想象一個(gè)場景,我們在銀行排隊(duì)辦理業(yè)務(wù),我們看看下面兩個(gè)模型。

(1)系統(tǒng)線程模型:

31.jpg

這種模型的問題顯而易見,服務(wù)端只有一個(gè)線程,并發(fā)請(qǐng)求(用戶)到達(dá)只能處理一個(gè),其余的要先等待,這就是阻塞,正在享受服務(wù)的請(qǐng)求阻塞后面的請(qǐng)求了。

(2)多線程、線程池模型:

32.jpg

這個(gè)模型已經(jīng)比上一個(gè)有所進(jìn)步,它調(diào)節(jié)服務(wù)端線程的數(shù)量來提高對(duì)并發(fā)請(qǐng)求的接收和響應(yīng),但并發(fā)量高的時(shí)候,請(qǐng)求仍然需要等待,它有個(gè)更嚴(yán)重的問題。到代碼層面上來講,我們看看客戶端請(qǐng)求與服務(wù)端通訊的過程:

33.jpg

服務(wù)端與客戶端每建立一個(gè)連接,都要為這個(gè)連接分配一套配套的資源,主要體現(xiàn)為系統(tǒng)內(nèi)存資源,以PHP為例,維護(hù)一個(gè)連接可能需要20M的內(nèi)存。這就是為什么一般并發(fā)量一大,就需要多開服務(wù)器。

那么NodeJS是怎么解決這個(gè)問題的呢?我們來看另外一個(gè)模型,想象一下我們在快餐店點(diǎn)餐吃飯的場景。

(3)異步、事件驅(qū)動(dòng)模型

34.jpg

我們同樣是要發(fā)起請(qǐng)求,等待服務(wù)器端響應(yīng);但是與銀行例子不同的是,這次我們點(diǎn)完餐后拿到了一個(gè)號(hào)碼,拿到號(hào)碼,我們往往會(huì)在位置上等待,而在我們后面的請(qǐng)求會(huì)繼續(xù)得到處理,同樣是拿了一個(gè)號(hào)碼然后到一旁等待,接待員能一直進(jìn)行處理。

等到飯菜做號(hào)了,會(huì)喊號(hào)碼,我們拿到了自己的飯菜,進(jìn)行后續(xù)的處理(吃飯)。這個(gè)喊號(hào)碼的動(dòng)作在NodeJS中叫做回調(diào)(Callback),能在事件(燒菜,I/O)處理完成后繼續(xù)執(zhí)行后面的邏輯(吃飯),這體現(xiàn)了NodeJS的顯著特點(diǎn),異步機(jī)制、事件驅(qū)動(dòng)整個(gè)過程沒有阻塞新用戶的連接(點(diǎn)餐),也不需要維護(hù)已經(jīng)點(diǎn)餐的用戶與廚師的連接。

基于這樣的機(jī)制,理論上陸續(xù)有用戶請(qǐng)求連接,NodeJS都可以進(jìn)行響應(yīng),因此NodeJS能支持比Java、PHP程序更高的并發(fā)量雖然維護(hù)事件隊(duì)列也需要成本,再由于NodeJS是單線程,事件隊(duì)列越長,得到響應(yīng)的時(shí)間就越長,并發(fā)量上去還是會(huì)力不從心。

總結(jié)一下NodeJS是怎么解決并發(fā)連接這個(gè)問題的:更改連接到服務(wù)器的方式,每個(gè)連接發(fā)射(emit)一個(gè)在NodeJS引擎進(jìn)程中運(yùn)行的事件(Event),放進(jìn)事件隊(duì)列當(dāng)中,而不是為每個(gè)連接生成一個(gè)新的OS線程(并為其分配一些配套內(nèi)存)。

2. I/O阻塞

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

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

35.jpg

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

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

36.jpg

NodeJS遇到I/O事件會(huì)創(chuàng)建一個(gè)線程去執(zhí)行,然后主線程會(huì)繼續(xù)往下執(zhí)行的,因此,拿profile的動(dòng)作觸發(fā)一個(gè)I/O事件,馬上就會(huì)執(zhí)行拿timeline的動(dòng)作,兩個(gè)動(dòng)作并行執(zhí)行,假如各需要1S,那么總的時(shí)間也就是1S。它們的I/O操作執(zhí)行完成后,發(fā)射一個(gè)事件,profile和timeline,事件代理接收后繼續(xù)往下執(zhí)行后面的邏輯,這就是NodeJS非阻塞I/O的特點(diǎn)。

2.安裝

http://nodejs.cn/download/,直接next

37.png

表示安裝成功。


 


??? ??

?? ??