五個最佳案例帶你解讀 Node.js 的先後之道

Node.js 是什麼? 

Node.js 採用 C++語言編寫而成,瀏覽器內核 V8 作爲執行引擎; Node 不是 JS 應用、而是一個 Javascript 的運行環境。 Node 保留了前端瀏覽器 js 的接口,沒有改寫語言自己的任何特性,依舊基於做用域和原型鏈。 

Node.js 是一個爲實時 Web ( Real-time Web )應用開發而誕生的平臺,它從誕生之初就充分考慮了在實時響應、超大規模數據要求下架構的可擴展性。這使得它摒棄了傳統平臺依靠多線程來實現高併發的設計思路,而採用了單線程、異步式 I/O 、事件驅動式的程序設計模型。這些特性不只帶來了巨大的性能提高,還減小了多線程程序設計的複雜性,進而提升了開發效率。 

Node.js 的特色 

1 、一個 Javascript 運行環境 
2 、依賴於 Chrome V8 引擎進行代碼解釋 
3 、事件驅動 
4 、非阻塞 I/O 
5 、輕量、可伸縮,適於實時數據交互應用 
6 、單進程,單線程 

Node.js 能作什麼? 

1 、具備複雜邏輯的網站 
2 、基於社交網絡的大規模 Web 應用; 
3 、 Web Socket 服務器(頁遊, web IM ); 
4 、 TCP/UDP 套接字應用程序; 
5 、命令行工具; 
6 、交互式終端程序; 
7 、帶有圖形用戶界面的本地應用程序; 
8 、單元測試工具; 
9 、客戶端 JavaScript 編譯器 

Node.js 架構 



事件循環 



NodeJs 執行模型: 單線程 Event Loop 

當應用請求發生時,首先進入 V8 引擎,而後進入到事件隊列,能夠理解爲他們在不斷地在循環,看是否有任務,產生任務就去執行。上圖是單線程模型。 

NPM 

後端在開發其餘語言時,都有一些模塊的概念或者第三方提供了很實用的小模塊。一樣, Node.js 當時出來的時候也有這樣一個倉庫。這個倉庫就是專門用來管理中國開發者的一個貢獻的模塊,並且發展很是的快。一樣,前端有一些腳手件,在服務器這邊運行的有 debug , express , express-session , thrift ,依託這個插件作 thrift 相關的事情, images 其餘的一些你想的到的插件,都是能夠從它找到。 

架構體系 




上圖是個推部分 WEB 平臺的架構體系,個推有一套雲組進資源,經過 Nginx 做爲一個分發, Node 能夠有多個節點,經過 session 進入。每個 Node 都有模式,相信你們在部署的時候確定不可能部署一個節點,部署一個節點,不然這個節點掛了就是掛了。 

Thrift 使用 

1 、定義接口 




2 、編譯,生成對應的包,並上傳到相應的庫中 
3 、在 Node 中使用,以下: 



注意:這裏有個坑 

thrift 中有個基本類型叫作 double ( 64 位浮點數)。當定義成這個類型時,數據從 java 過來到 Node 會變成全是 0 。 

解決方案 

定義成 string 類型,以後特事特辦,如必要則在 Node 處再轉成浮點數,或者直接由頁面端處理。 
IP 負載( IP Load Balance ) 

負載均衡 

分攤到多個操做單元上進行執行,例如 Web 服務器、 FTP 服務器、企業關鍵應用服務器和其它關鍵任務服務器等,從而共同完成工做任務。 
原生中其並無負載均衡的機制,但咱們能夠採用動態代理的設計模式,基於 thrift client ,利用 JS 的原型鏈來實現。 
均衡的方式有不少種,咱們使用輪詢機制來實現訪問多個 Java 節點。 

session 管理 

Node 自己並沒有 session 機制,咱們可使用 express-session 包來實現,同時經過 redis 來存儲 session 。 

鏈接池 

傳統讀取數據庫方式: 



鏈接池須要作什麼? 

1 、鏈接預熱 (啓動時自動打開 n 個鏈接以供使用) 
2 、使用 例如 輪轉法 均勻分發 鏈接請求 
3 、當池中的鏈接即將耗盡得時候動態產生新的鏈接 
4 、當池中的鏈接一段時間沒有被調用的時候,自動釋放鏈接 
5 、自動丟棄 已經壞掉的 鏈接 
6 、系統關閉的時自動釋放全部鏈接 

基於此,咱們也能夠藉助幾個插件包(如 generic-pool ( node-pool )、 node-thrift-pool ,固然,若是你直接 Node 鏈接的 DB ,基本上那個包裏面也會支持鏈接池)在 Node 使用鏈接池。 

使用示例 




利用 Node 能夠作的事情 

1 、作一些灰色地帶的事情 
利用 Node 能夠作一些灰色地帶的事情,由於它擁有前端的優勢,能夠異步,發起異步請求。給開發者帶來很大的好處。不過,你須要管理好你的類型。若是說類型本身若是沒有管理好就是會出現一些問題。同時它也能夠作後端的一些事情。好比說鏈接池等等。 
2 、模塊更加分明 
3 、可前可後便於分工 
從瀏覽器過來的數據,經過 Node 把這一層數據轉化成 java 須要的一種數據結構,就可使得分工更加明晰。 
4 、共用表單輸入驗證 
若是你在寫系統的時候,出於安全考慮,不管瀏覽器這邊作了多少驗證,你都要作輸入驗證。傳統模式下是須要 java 同窗寫一份,前端同窗寫一份。由於 Node 跟 java 都是部署在服務器集羣或者一個區域,你能夠相信這兩邊之間一個數據。來自瀏覽器的驗證,就能夠共用表單輸入驗證,達到節省成本的目的。 

以上內容來自個推 web 服務首席架構師姜季廷在 3 月 12 日 SegmentFault D-Day 北京:後端的演講整理而成。前端

本文來自https://www.v2ex.com/t/266827java

相關文章
相關標籤/搜索