亚洲免费av电影一区二区三区,日韩爱爱视频,51精品视频一区二区三区,91视频爱爱,日韩欧美在线播放视频,中文字幕少妇AV,亚洲电影中文字幕,久久久久亚洲av成人网址,久久综合视频网站,国产在线不卡免费播放

        ?

        Node.js服務(wù)器技術(shù)初探

        2014-06-20 13:35:02駱文亮
        無線互聯(lián)科技 2014年3期

        駱文亮

        摘 要:通過對Node.js技術(shù)的簡介,引出Node.js的基本概念、功能和它能解決的問題以及Node.js的應(yīng)用場景。

        關(guān)鍵詞:Java;JSON;Javascript

        1 引言

        從2009年Node.js的誕生至今,已有近5年時間,其成長速度令人咂舌。國外大量的社區(qū)對Node.js的前景充分肯定,各種實際應(yīng)用層出不窮。而國內(nèi)這方面發(fā)展相對緩慢,Node.js中文社區(qū)也活躍著很多開發(fā)者。本文通過對Node.js的介紹,提出Node.js的基本概念、功能和實際應(yīng)用場合。希望對開發(fā)人員有所幫助。

        2 Node.js簡介

        2.1 Google V8 JavaScript引擎

        Google公司著名的瀏覽器Chrome瀏覽器就是基于Google V8 JavaScript引擎的高速瀏覽器。V8是由丹麥Google開發(fā)的開源JavaScript引擎。V8在執(zhí)行之前將JavaScript編譯成了機器碼,而非位元組碼或是直譯它,以此提升效能。更進一步,使用了如內(nèi)聯(lián)緩存(inline caching)等方法來提高性能。有了這些功能,JavaScript程序與V8引擎的速度媲美二進制編譯。

        為了縮短由垃圾收集造成的停頓,V8使用stop-the-world, generational, accurate的垃圾收集器。在執(zhí)行回收之時會暫時中斷程序的執(zhí)行,而且只處理物件堆疊。還會收集內(nèi)存內(nèi)所有物件的指標(biāo),可以避免內(nèi)存溢位的情況。

        2.2 Node.js基本概念

        Node.js是服務(wù)器端的JavaScript運行環(huán)境,它具有無阻塞(non-blocking)和事件驅(qū)動(event-driven)等的特色,Node.js采用V8引擎,同樣,Node.js實現(xiàn)了類似Apache和 nginx的web服務(wù),讓你可以通過它來搭建基于JavaScript的 Web App。

        Node.js是一個可以快速構(gòu)建網(wǎng)絡(luò)服務(wù)及應(yīng)用的平臺,它的構(gòu)建是基于Chrome's JavaScript runtime,它可以很好地工作與非瀏覽器環(huán)境??傊?,Node.js是一個脫離了瀏覽器的Javascript。

        3 Node.js功能

        3.1 Node.js解決的問題

        在很多情況下,服務(wù)器端的性能瓶頸主要在于大量的數(shù)據(jù)請求讓服務(wù)器疲于應(yīng)付,造成大量的阻塞。Node.JS的誕生就是用來解決服務(wù)端阻塞問題。例如,當(dāng)客戶端通過一句查詢語句來查詢一些信息時,程序進程往往只是在等待結(jié)果的返回,浪費了大量的時間不說,還這就造成了進程的阻塞。在對于高并發(fā),I/O密集型的WebAPP中,一方面服務(wù)器讓進程很長時間處于等待狀態(tài),另一方面為了應(yīng)付新的請求不斷的增加新的進程。這樣的浪費會導(dǎo)致系統(tǒng)的實際性能遠遠小于它能夠支撐性能,這個就是系統(tǒng)的瓶頸,而且這樣的系統(tǒng)也特別容易被黑客利用慢鏈接攻擊。

        3.2 Node.js解決問題的基本思路

        Node.js解決阻塞問題的思路是,建立一種事件機制,發(fā)起查詢請求之后,立即將進程交出,當(dāng)數(shù)據(jù)返回后觸發(fā)事件,再繼續(xù)處理數(shù)據(jù)。

        要達到上述目的,需要語言能夠提供一套高效的異步事件調(diào)度機制。而主要用于處理瀏覽器端的各種交互事件的JavaScript相對于其他語言,至少有兩個關(guān)鍵點特別適合完成這個任務(wù):

        1)JavaScript是一種函數(shù)式編程語言,函數(shù)編程語言最重要的數(shù)學(xué)基礎(chǔ)是λ演算(lambda calculus)——即函數(shù)可以接受函數(shù)當(dāng)作輸入(參數(shù))和輸出(返回值)。

        2)JavaScript支持“閉包”。在復(fù)雜的應(yīng)用中,一定會遇到這類場景。即在函數(shù)運行時需要訪問函數(shù)定義時的上下文數(shù)據(jù)。而在異步編程中,函數(shù)的定義和運行又分處不同的時間段,那么保持上下文的問題變得更加突出。JavaScript支持的“閉包”能夠較好地處理這個問題。

        4 Node.js應(yīng)用場景

        4.1 I/O密集型

        在I/O密集型的應(yīng)用場景中,Node,js的并行I/O能力,能夠非常有效地利用的硬件資源,從而提供更多好的服務(wù)。I/O密集的優(yōu)勢主要在于Node利用事件循環(huán)的處理能力,而不是啟動每一個線程為每一個請求服務(wù),資源占用極少。

        4.2 不擅長CPU密集型

        最顯而易見的情況就是是那種CPU使用率高同時I/O操作小的。所以如果你打算寫一個視頻編碼軟件,人工智能軟件或者類似的CPU使用率高的軟件,請不要用node.js。

        4.3 分布式應(yīng)用

        淘寶的數(shù)據(jù)平臺是國內(nèi)對Node的分布式應(yīng)用是一個典型的例子。分布式應(yīng)用意味著對可伸縮性的要求非常高。數(shù)據(jù)平臺通常要在一個數(shù)據(jù)庫集群中去尋找需要的數(shù)據(jù)。這個案例其實也是高效利用并行I/O的例子。Node高效利用并行I/O的過程,也是高效使用數(shù)據(jù)庫的過程。對于Node,這個行為只是一次普通的I/O。對于數(shù)據(jù)庫而言,卻是一次復(fù)雜的計算,所以也是進而充分壓榨硬件資源的過程。

        5 結(jié)束語

        從本文可以看出,Node完成了它提供高度可伸縮服務(wù)器的目標(biāo)。它使用了Google的一個非??焖俚腏avaScript引擎,即V8引擎。它使用一個事件驅(qū)動設(shè)計來保持代碼最小且易于閱讀。所有這些因素促成了Node的理想目標(biāo),即編寫一個高度可伸縮的解決方案變得比較容易。

        [參考文獻]

        [1]Mike Cantelon,TJ Holowaychuk.Node.js in Action 2011.

        [2]http://limu.iteye.com/blog/1013223.,2013-01-17.

        [3]http://cnodejs.org/topic/4f97d5b8407edba21.2013-04-23.

        [4]樸靈.深入淺出Node.js.人民郵電出版社.

        亚洲一区二区三区偷拍厕所| 中文人妻无码一区二区三区信息| 亚洲高清国产品国语在线观看| 一区二区黄色素人黄色| 蜜桃尤物在线视频免费看| 亚洲av无码一区二区三区人| 乱子真实露脸刺激对白| 亚洲日本国产乱码va在线观看| 国产愉拍91九色国产愉拍| 摸丰满大乳奶水www免费| 日产国产精品亚洲系列| 日韩精品欧美激情亚洲综合| 久久免费看视频少妇高潮| 天天做天天爱夜夜夜爽毛片| 伊人久久大香线蕉亚洲五月天| 五月天久久国产你懂的| 国产精东一区二区三区| 蜜桃传媒一区二区亚洲av婷婷| 国产精品亚洲一区二区在线观看| 日本在线视频网站www色下载 | 狂猛欧美激情性xxxx大豆行情 | 国产91成人精品高潮综合久久| 国产激情综合在线观看| 无码人妻丰满熟妇精品区| 蜜桃在线观看免费高清完整版| 在线免费看91免费版.| 精品国产拍国产天天人| 国产成人精品精品欧美| av在线男人的免费天堂| 情爱偷拍视频一区二区| 一区二区三区国产亚洲网站| 麻豆密入视频在线观看| 大陆少妇一区二区三区| 比较有韵味的熟妇无码| 日本五月天婷久久网站| 久久爱91精品国产一区| 国产精品第一二三区久久| 最近最新中文字幕| 日本高清不在线一区二区色| 国产亚洲综合另类色专区| 亚洲愉拍99热成人精品热久久|