设为首页 收藏本站
查看: 1198|回复: 0

[经验分享] 用Nginx做NodeJS应用的负载均衡

[复制链接]

尚未签到

发表于 2015-12-23 13:45:06 | 显示全部楼层 |阅读模式
《用Nginx做NodeJS应用的负载均衡》负载均衡可以把用户的请求分摊到多个服务器上进行处理,从而实现了对海量用户的访问支持。负载均衡的架构如图所示:
DSC0000.jpg
对于复杂的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://sample做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服务器
现在我们可以访问http://127.0.0.1
可以看到如下的输出:
  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

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-155279-1-1.html 上篇帖子: nodejs解析apk 下篇帖子: Docker体验之:在MACOS下安装docker并构建nodejs开发环境
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表