負載平衡可以把使用者的請求分攤到多個伺服器上處理,從而實現了對海量用戶的存取支援。負載平衡的架構如圖所示:
對於複雜的web應用來說,用nginx做前端負載平衡是理所當然的事。
下面,我們用nginx做nodejs應用的負載平衡。
1、設定nginx
修改nginx.conf:
upstream sample { server 127.0.0.1:3000; server 127.0.0.1:3001; keepalive 64; } server { listen 80; .... server_name 127.0.0.1; .... location / { proxy_redirect off; proxy_set_header x-real-ip $remote_addr; proxy_set_header x-forwarded-for $proxy_add_x_forwarded_for; proxy_set_header x-forwarded-proto $scheme; proxy_set_header host $http_host; proxy_set_header x-nginx-proxy true; proxy_set_header connection ""; proxy_http_version 1.1; proxy_pass http://sample; } }
這裡在3000埠和3001埠各有一個node.js伺服器,這兩台伺服器在做同樣的工作。在upstream節,配置了兩台node.js伺服器。此外,我們也設定了proxy_pass 做http請求代理。
2、建置nodejs伺服器
var http = require('http'); var morgan = require('morgan'); var server1 = http.createserver(function (req, res) { console.log("request for: " + req.url + "-- port 3000 "); res.writehead(200, {'content-type': 'text/plain'}); res.end('hello node.js\n'); }).listen(3000, "127.0.0.1"); var server2 = http.createserver(function (req, res) { console.log("request for: " + req.url + "-- port 3001 "); res.writehead(200, {'content-type': 'text/plain'}); res.end('hello node.js\n'); }).listen(3001, "127.0.0.1"); server1.once('listening', function() { console.log('server running at http://127.0.0.1:3000/'); }); server2.once('listening', function() { console.log('server running at http://127.0.0.1:3001/'); });
#3、存取nginx伺服器
現在我們可以存取
可以看到如下的輸出:
server running at http://127.0.0.1:3000/ server running at http://127.0.0.1:3001/ request for: /-- port 3001 request for: /favicon.ico-- port 3000 request for: /favicon.ico-- port 3001 request for: /-- port 3000 request for: /favicon.ico-- port 3001 request for: /favicon.ico-- port 3000 request for: /-- port 3001 request for: /favicon.ico-- port 3000 request for: /favicon.ico-- port 3001 request for: /-- port 3000 request for: /favicon.ico-- port 3001 request for: /favicon.ico-- port 3000
以上是Nginx做NodeJS應用負載平衡配置的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!