1.什么是Node.js
1.Node.js是一個讓JavaScript運(yùn)行在服務(wù)器端的開發(fā)平臺蔓纠,它讓JavaScript的觸角伸到了服務(wù)器端祟剔,可以與PHP位迂、JSP乳蛾、Python焕襟、Ruby平起平坐橄镜。
2.Node.js不是一種獨(dú)立的語言蛀缝,與PHP萤厅、JSP暇藏、Python蜜笤、Perl、Ruby的“既是語言盐碱,也是平臺”不同把兔,Node.js的使用JavaScript進(jìn)行編程,運(yùn)行在JavaScript引擎上(V8)
3.Node.js與PHP瓮顽、JSP等相比(PHP县好、JSP、.net都需要運(yùn)行在服務(wù)器程序上趣倾,Apache聘惦、Naginx、Tomcat、IIS善绎。
)黔漂,Node.js跳過了Apache、Naginx禀酱、IIS等HTTP服務(wù)器炬守,它自己不用建設(shè)在任何服務(wù)器軟件之上。Node.js的許多設(shè)計理念與經(jīng)典架構(gòu)(LAMP = Linux + Apache + MySQL + PHP)有著很大的不同剂跟,可以提供強(qiáng)大的伸縮能力
2.Node.js特點(diǎn)
- 1).單線程
a. 在Java减途、PHP或者.net等服務(wù)器端語言中,會為每一個客戶端連接創(chuàng)建一個新的線程曹洽。而每個線程需要耗費(fèi)大約2MB內(nèi)存鳍置。也就是說,理論上送淆,一個8GB內(nèi)存的服務(wù)器可以同時連接的最大用戶數(shù)為4000個左右税产。要讓W(xué)eb應(yīng)用程序支持更多的用戶,就需要增加服務(wù)器的數(shù)量偷崩,而Web應(yīng)用程序的硬件成本當(dāng)然就上升了辟拷。
b. Node.js不為每個客戶連接創(chuàng)建一個新的線程,而僅僅使用一個線程阐斜。當(dāng)有用戶連接了衫冻,就觸發(fā)一個內(nèi)部事件,通過非阻塞I/O谒出、事件驅(qū)動機(jī)制隅俘,讓Node.js程序宏觀上也是并行的。使用Node.js到推,一個8GB內(nèi)存的服務(wù)器考赛,可以同時處理超過4萬用戶的連接。
- 2).非阻塞I/O non-blocking I/O
a. 在傳統(tǒng)的單線程處理機(jī)制中莉测,在執(zhí)行了訪問數(shù)據(jù)庫代碼之后,整個線程都將暫停下來唧喉,等待數(shù)據(jù)庫返回結(jié)果捣卤,才能執(zhí)行后面的代碼。也就是說八孝,I/O阻塞了代碼的執(zhí)行董朝,極大地降低了程序的執(zhí)行效率。
b. 由于Node.js中采用了非阻塞型I/O機(jī)制干跛,因此在執(zhí)行了訪問數(shù)據(jù)庫的代碼之后子姜,將立即轉(zhuǎn)而執(zhí)行其后面的代碼,把數(shù)據(jù)庫返回結(jié)果的處理代碼放在回調(diào)函數(shù)中楼入,從而提高了程序的執(zhí)行效率哥捕。
當(dāng)某個I/O執(zhí)行完畢時牧抽,將以事件的形式通知執(zhí)行I/O操作的線程,線程執(zhí)行這個事件的回調(diào)函數(shù)遥赚。為了處理異步I/O扬舒,線程必須有事件循環(huán),不斷的檢查有沒有未處理的事件凫佛,依次予以處理讲坎。
c. 阻塞模式下,一個線程只能處理一項任務(wù)愧薛,要想提高吞吐量必須通過多線程晨炕。而非阻塞模式下,一個線程永遠(yuǎn)在執(zhí)行計算操作毫炉,這個線程的CPU核心利用率永遠(yuǎn)是100%瓮栗。
- 3.)事件驅(qū)動event-driven
在Node中,客戶端請求建立連接碘箍,提交數(shù)據(jù)等行為遵馆,會觸發(fā)相應(yīng)的事件。在Node中丰榴,在一個時刻货邓,只能執(zhí)行一個事件回調(diào)函數(shù),但是在執(zhí)行一個事件回調(diào)函數(shù)的中途四濒,可以轉(zhuǎn)而處理其他事件(比如换况,又有新用戶連接了),然后返回繼續(xù)執(zhí)行原事件的回調(diào)函數(shù)盗蟆,這種處理機(jī)制戈二,稱為“事件環(huán)”機(jī)制。
3.適合開發(fā)什么喳资?
a. 善于I/O觉吭,不善于計算。因為Node.js最擅長的就是任務(wù)調(diào)度仆邓,如果你的業(yè)務(wù)有很多的CPU計算鲜滩,實際上也相當(dāng)于這個計算阻塞了這個單線程,就不適合Node開發(fā)节值。
b. 當(dāng)應(yīng)用程序需要處理大量并發(fā)的I/O徙硅,而在向客戶端發(fā)出響應(yīng)之前,應(yīng)用程序內(nèi)部并不需要進(jìn)行非常復(fù)雜的處理的時候搞疗,Node.js非常適合嗓蘑。Node.js也非常適合與web socket配合,開發(fā)長連接的實時交互應(yīng)用程序。