Node.js本質上是一個JavaScript的運行環境。前端
Node.js是一個基於Chrome JavaScript運行時創建的平臺, 用於方便地搭建響應速度快、易於擴展的網絡應用。Node.js使用事件驅動,非阻塞I/O 模型而得以輕量和高效,很是適合在分佈式設備上運行數據密集型的實時應用。node
課程連接:Node.js 入門教程(文檔)數據庫
V8引擎自己使用了一些最新的編譯技術。這使得用Javascript這類腳本語言編寫出來的代碼運行速度得到了極大提高,又節省了開發成本。對性能的苛求是Node的一個關鍵因素。 Javascript是一個事件驅動語言,Node利用了這個優勢,編寫出可擴展性高的服務器。Node採用了一個稱爲「事件循環(event loop)」的架構,使得編寫可擴展性高的服務器變得既容易又安全。提升服務器性能的技巧有多種多樣。Node選擇了一種既能提升性能,又能減低開發複雜度的架構。這是一個很是重要的特性。併發編程一般很複雜且佈滿地雷。Node繞過了這些,但仍提供很好的性能。編程
Node採用一系列「非阻塞」庫來支持事件循環的方式。本質上就是爲文件系統、數據庫之類的資源提供接口。向文件系統發送一個請求時,無需等待硬盤(尋址並檢索文件),硬盤準備好的時候非阻塞接口會通知Node。該模型以可擴展的方式簡化了對慢資源的訪問, 直觀,易懂。尤爲是對於熟悉onmouseover、onclick等DOM事件的用戶,更有一種似曾相識的感受。
雖然讓Javascript運行於服務器端不是Node的獨特之處,但倒是其一強大功能。不得不認可,瀏覽器環境限制了咱們選擇編程語言的自由。任何服務器與日益複雜的瀏覽器客戶端應用程序間共享代碼的願望只能經過Javascript來實現。雖然還存在其餘一些支持Javascript在服務器端 運行的平臺,但由於上述特性,Node發展迅猛,成爲事實上的平臺。
在Node啓動的很短期內,社區就已經貢獻了大量的擴展庫(模塊)。其中不少是鏈接數據庫或是其餘軟件的驅動,但還有不少是憑他們的實力製做出來的很是有用的軟件。瀏覽器
最後,不得不提到的是Node社區。雖然Node項目還很是年輕,但不多看到對一個項目如此狂熱的社區。不論是新手,仍是專家,你們都圍繞着項目,使用並貢獻本身的能力,致力於打造一個探索、支持、分享、聽取建議的樂土。安全
Node.js的優勢:前端框架
nodejs做爲一個新興的前端框架,後臺語言,有不少吸引人的地方:服務器
Node不適應的場景: 網絡
在Node.js 0.8 版本以前,Node.js 不支持多線程。固然,這是一種設計哲學問題,由於Node.js的開發者和支持者堅信單線程和事件驅動的異步式編程比傳統的多線程編程運行效率更高。但事實上多線程能夠達到一樣的吞吐量,儘管可能開銷不小,但沒必要爲多核環境進行特殊的配置。相比之下,Node.js 因爲其單線程性的特性,必須經過多進程的方法才能充分利用多核資源。多線程
理想狀況下,Node.js單線程在執行的過程當中會將一個CPU核心徹底佔滿,全部的請求必須等待當前請求處理完畢之後進入事件循環才能響應。若是一個應用是計算密集型的,那麼除非你手動將它拆散,不然請求響應延遲將會至關大。例如,某個事件的回調函數中要進行復雜的計算,佔用CPU 200毫秒,那麼事件循環中全部的請求都要等待200毫秒。爲了提升響應速度,你惟一的辦法就是把這個計算密集的部分拆成若干個邏輯,這給編程帶來了額外的複雜性。即便這樣,系統的總吞吐量和總響應延遲也不會下降,只是調度稍微公平了一些。不過好在真正的Web 服務器中,不多會有計算密集的部分,若是真的有,那麼它不該該被實現爲即時的響應。正確的方式是給用戶一個提示,說服務器正在處理中,完成後會通知用戶,而後交給服務器的其餘進程甚至其餘專職的服務器來作這件事。
前面咱們討論的一般都是服務器端編程,其中一個假設就是用戶數量不少。但若是面對的是單用戶,譬如本地的命令行工具或者圖形界面,那麼所謂的大量併發請求就不存在了。因而另外一個恐怖的問題出現了,儘管是單用戶,卻不必定是單任務。例如給用戶提供界面的同時後臺在進行某個計算,爲了讓用戶界面不出現阻塞狀態,你不得不開啓多線程或多進程。而Node.js 線程或進程之間的通訊到目前爲止還很不便,由於它根本沒有鎖,於是號稱不會死鎖。Node.js 的多進程每每是在執行同一任務,經過多進程利用多處理器的資源,但遇到多進程相互協做時,就顯得捉襟見肘了。
Node.js 的控制流不是線性的,它被一個個事件拆散,但人的思惟倒是線性的,當你試圖轉換思惟來迎合語言或編譯器時,就不得不做出犧牲。舉例來講,你要實現一個這樣的邏輯:從銀行取錢,拿錢去購買某個虛擬商品,買完之後加入庫存數據庫,這中間的任何一步均可能會涉及數十次的I/O操做,並且任何一次操做失敗之後都要進行回滾操做。這個過程是線性的,已經很複雜了,若是要拆分爲非線性的邏輯,那麼其複雜程度極可能就達到沒法維護的地步了。Node.js更善於處理那些邏輯簡單但訪問頻繁的任務,而不適合完成邏輯十分複雜的工做。
更多精品課程:
阿里雲大學官網(阿里雲大學 - 官方網站,雲生態下的創新人才工場)