提高Node.js性能的應(yīng)用技巧分享
一、實(shí)現(xiàn)一個(gè)反向代理服務(wù)器
相比大多數(shù)應(yīng)用服務(wù)器,Node.js 可以很輕松的處理大量的網(wǎng)絡(luò)流量,但這并不是 Node.js 的設(shè)計(jì)初衷。
如果你有一個(gè)高流量的站點(diǎn),提高性能的第一步是在你的 Node.js 前面放一個(gè)反向代理服務(wù)器。這可以保護(hù)你的 Node.js 服務(wù)器免于直接暴露在網(wǎng)絡(luò)中,而且可以允許你靈活的使用多個(gè)應(yīng)用服務(wù)器做負(fù)載均衡和靜態(tài)文件緩存。
使用 NGINX 在一個(gè)已經(jīng)存在的服務(wù)器前做反向代理,作為 NGINX 的一個(gè)核心應(yīng)用,已經(jīng)被用于全世界成千上萬(wàn)的站點(diǎn)中。
下面是使用 NGINX 作為反向代理服務(wù)器的優(yōu)點(diǎn):
簡(jiǎn)化了權(quán)限處理和端口分配
更高效的處理靜態(tài)資源
更好的處理 Node.js 崩潰情況
緩解 DoS 攻擊的影響
注:這篇文章解釋如何在 Ubuntu 14.04 或者 CentOS 環(huán)境中使用 NGINX 做反向代理服務(wù)器,而且使用 NGINX 在 Node.js 前做反向代理服務(wù)器是有效的。
二、緩存靜態(tài)文件
隨著流量的增長(zhǎng),以 Node 為基礎(chǔ)的服務(wù)器開(kāi)始顯現(xiàn)壓力。這時(shí),你可能想做兩件事:
使用更多的 Node.js 服務(wù)器。
在多個(gè)服務(wù)器間做負(fù)載均衡
這其實(shí)很簡(jiǎn)單,NGINX 一開(kāi)始就是作為反向代理服務(wù)器來(lái)實(shí)現(xiàn)的,這使其很容易做緩存和負(fù)載均衡等。
Modulus 的網(wǎng)站有一篇有用的文章,介紹了使用 NGINX 做 Node.js 反向代理服務(wù)器的性能提升。只使用 Node.js 時(shí),作者的網(wǎng)站每秒能處理 900 個(gè)請(qǐng)求。 使用 NGINX 作為反向代理服務(wù)器來(lái)處理靜態(tài)文件后,該網(wǎng)站每秒可處理超過(guò) 1600 個(gè)請(qǐng)求,接近兩倍的性能提升。
下面是該網(wǎng)站做上述性能提升的配置代碼:
nginx server { listen 80; server_name static-test-47242.onmodulus.net; root /mnt/app; index index.html index.htm; location /static/ { try_files $uri $uri/ =404; } location /api/ { proxy_pass http://node-test-45750.onmodulus.net; } }
三、實(shí)現(xiàn) Node.js 負(fù)載均衡
最終目標(biāo)— Node.js 運(yùn)行多個(gè)應(yīng)用服務(wù)器,并在這些服務(wù)器之間均衡負(fù)載。
Node.js 實(shí)現(xiàn)負(fù)載均衡是比較困難的,因?yàn)?Node.js 允許瀏覽器端 JavaScript 和 服務(wù)器端 Node.js 通過(guò) json 做數(shù)據(jù)交互,這就意味著同一個(gè)客戶端可以反復(fù)的訪問(wèn)一個(gè)特定的應(yīng)用服務(wù)器,而且多個(gè)應(yīng)用服務(wù)器之間共享 session也是比較困難的。
NGINX 實(shí)現(xiàn)無(wú)狀態(tài)負(fù)載均衡的方式:
Round Robin. 新的請(qǐng)求去列表中的下一個(gè)服務(wù)器
Least Connections. 新的請(qǐng)求去連接數(shù)最少的服務(wù)器
IP Hash. 根據(jù)客戶端 IP 的 hash 值指定服務(wù)器
只有 IP Hash 這一種能夠可靠的把客戶端請(qǐng)求代理到同一臺(tái)服務(wù)器的方式才能使 Node.js 應(yīng)用服務(wù)器受益。
四、代理 WebSocket 連接
所有版本的 HTTP 都是為客戶端主動(dòng)請(qǐng)求服務(wù)器來(lái)設(shè)計(jì)的,而 WebSocket 可以實(shí)現(xiàn)服務(wù)器主動(dòng)向客戶端的消息推送。
WebSocket 協(xié)議使客戶端和服務(wù)器端的穩(wěn)定交互更加簡(jiǎn)單,同時(shí)也提供更小的交互延遲。當(dāng)你需要一個(gè)全雙工的通訊,即客戶端和服務(wù)器都可以在需要時(shí)主動(dòng)發(fā)起消息請(qǐng)求,那么使用 WebSocket 就對(duì)了。
WebSocket 協(xié)議有健全的 JavaScript 接口,因此也原生適合用 Node.js 作為應(yīng)用服務(wù)器。當(dāng)連接數(shù)上升,使用 NGINX 在客戶端和 Node.js 服務(wù)器端做代理來(lái)緩存靜態(tài)文件和負(fù)載均衡就變得非常有意義。
五、實(shí)現(xiàn) SSL/TLS 和 HTTP/2
越來(lái)越多的網(wǎng)站使用 SSL/TLS 來(lái)保證信息交互的安全性,你也可以考慮是否要把它加入到你的網(wǎng)站中,但如果你決定要做,那么 NGINX 有兩種方式來(lái)支持它:
你可以使用 NGINX 做 SSL/TLS 反向代理,Node.js 服務(wù)器使用解密后的請(qǐng)求然后返回未加密的內(nèi)容給 NGINX。
使用 HTTP/2 可以抵消 SSL/TLS 帶來(lái)的性能開(kāi)銷(xiāo),NGINX 支持 HTTP/2, 所以你可以同時(shí)使用 HTTP/2 和 SSL 代理請(qǐng)求,而你的 Node.js 服務(wù)器不需要做任何更改。
在實(shí)現(xiàn)階段你需要更新 Node.js 配置文件中的 URL, 在你的 NGINX 配置文件中使用 SPDY 或者 HTTP/2 優(yōu)化連接。添加 HTTP/2 支持意味著支持 HTTP/2 的瀏覽器可以使用新的協(xié)議和你的應(yīng)用交互,而老的瀏覽器繼續(xù)使用 HTTP/1.x。
相關(guān)文章
nodejs中使用HTTP分塊響應(yīng)和定時(shí)器示例代碼
本文通過(guò)示例將要?jiǎng)?chuàng)建一個(gè)輸出純文本的HTTP服務(wù)器,輸出的純文本每隔一秒會(huì)新增100個(gè)用換行符分隔的時(shí)間戳。實(shí)例代碼非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下2017-03-03利用node 判斷打開(kāi)的是文件 還是 文件夾的實(shí)例
今天小編就為大家分享一篇利用node 判斷打開(kāi)的是文件 還是 文件夾的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-06-06koa+jwt實(shí)現(xiàn)token驗(yàn)證與刷新功能
這篇文章主要介紹了koa+jwt實(shí)現(xiàn)token驗(yàn)證與刷新功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-05-05nodejs 實(shí)現(xiàn)模擬form表單上傳文件
使用nodejs來(lái)模擬form表單進(jìn)行文件上傳,可以同時(shí)上傳多個(gè)文件。2014-07-07詳解如何在vscode里面調(diào)試js和node.js的方法步驟
這篇文章主要介紹了詳解如何在vscode里面調(diào)試js和node.js的方法步驟,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-12-12node.js中的http.createClient方法使用說(shuō)明
這篇文章主要介紹了node.js中的http.createClient方法使用說(shuō)明,本文介紹了http.createClient的方法說(shuō)明、語(yǔ)法、接收參數(shù)、使用實(shí)例和實(shí)現(xiàn)源碼,需要的朋友可以參考下2014-12-12NodeJS Web應(yīng)用監(jiān)聽(tīng)sock文件實(shí)例
這篇文章主要介紹了NodeJS Web應(yīng)用監(jiān)聽(tīng)sock文件實(shí)例,本文講解 NodeJS 的 TCP 和 HTTP 監(jiān)聽(tīng) Domain Socket 文件例子,需要的朋友可以參考下2015-02-02Node.js檢測(cè)端口(port)是否被占用的簡(jiǎn)單示例
大家有沒(méi)有遇到過(guò)在開(kāi)啟本地服務(wù)時(shí),有這么一種情況:當(dāng)前端口已經(jīng)被另一個(gè)項(xiàng)目使用了,導(dǎo)致服務(wù)開(kāi)啟失敗。那么接下來(lái),我們通過(guò)簡(jiǎn)簡(jiǎn)單單的示例代碼來(lái)檢測(cè)端口是否已經(jīng)被占用。有需要的朋友們可以參考借鑒。2016-09-09