文档章节

nginx nodejs负载均衡

wisdomofgod
 wisdomofgod
发布于 2015/04/19 18:53
字数 401
阅读 33
收藏 0

一:安装nginx

sudo apt-get install nginx

二:启动nginx

sudo /etc/init.d/nginx start

三:查看配置文件

gedit /etc/nginx/nginx.conf

发现 include /etc/nginx/sites-enable/*

server并没有直接在nginx.conf里  配置 (这跟 源代码安装的不同)

源代码安装的 配置文件在 gedit /usr/local/nginx/conf/nginx.conf

并且server配置直接写在了conf文件里


四:找到 /etc/nginx/sites-enable/default

sudo gedit /etc/nginx/sites-enbale/default

把原来默认的 server  用#备注  或者直接删除

添加如下代码:

upstream nodejs {

    server 127.0.0.1:3000;            //可以加上 weight=5;  代表权重  值越大分配比重越大  没有则平均分配

    server 127.0.0.1:3001;

    keepalive 64;

}


server {

    listen 80;                                            //端口号

    server_name localhost 127.0.0.1;     //URL

    access_log /var/log/nginx/test.log;

    location / {

        proxy_set_header X-Real-IP $remote_addr;

        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

        proxy_set_header Host  $http_host;

        proxy_set_header X-Nginx-Proxy true;

        proxy_set_header Connection "";

        proxy_pass      http://nodejs;                

    }

}

五:添加测试文件 http.js

var http = require('http'); 

  

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/'); 

});

六:运行并生成日记

node http.js>http.log        

七:负载均衡测试

1,安装siege

sudo apt-get install siege

2,启动siege

sudo siege -c 50 http://localhost        //每秒发送50个并发请求

3,运行一段时间  ctrl+c  停止siege

4,查看http.log文件

5,安装R语言 分析http.log

sudo apt-get install r-base-core

6,运行R命令

R

>df<-read.table(file="http.log",skip=9,header=FALSE)

>summary(df)

>q()


负载均衡测试 转自:http://blog.fens.me/nodejs-core-cluster/

© 著作权归作者所有

共有 人打赏支持
上一篇: 父子节点
wisdomofgod
粉丝 0
博文 31
码字总数 9078
作品 0
厦门
程序员
私信 提问
5个提高Node.js应用性能的技巧

“如果你的 node 服务器前面没有 nginx, 那么你可能做错了。”— Bryan Hughes Node.js 是使用 最流行的语言— JavaScript 构建服务器端应用的领先工具 。由于可以同时提供 web 服务器和应用...

力谱宿云
2016/04/14
350
0
Roosevelt 0.4.8 发布, Node.js 的 Web 框架

Roosevelt 0.4.8 版本支持多核负载均衡,有更好的依赖关系管理,允许在负载均衡工具(比如:pm2)中运行,修复了在标准 Apache 或者 nginx 部署配置上的默认错误页面,修复了在新版 Node.js ...

oschina
2013/12/15
812
0
Node.js 2018 用户调查:最爱 Express,最想学 Rust

Node.js 基金会近日发布了 2018 Node.js 用户调查报告,这是该基金会举报的第三届年度用户调查,于 2017 年 10 月 5 日开始,截止至 2018 年 1 月 7 日,旨在了解用户平常使用 Node.js 的偏好...

王练
06/06
2.8K
15
socket.io搭建分布式web推送服务器

socket.io是目前较为流行的web实时推送框架,其基于nodejs语言开发,底层用engine.io实现。 借助nodejs语言异步的特性,其获得了不错的性能。但单个实例的socket.io依然承载能力有限,最多只...

骨头bone
2014/10/16
0
18
谁说前端需要懂 Nginx 了?

--读《谁说前端不需要懂-Nginx反向代理与负载均衡》有感 读了上文发现内容虽然还是挺好的,但看完,为啥要懂nginx呀,负载均衡和前端哪里有什么半毛钱关系了,没说清楚呀。 当然这个面向前端...

vellengs
06/22
0
0

没有更多内容

加载失败,请刷新页面

加载更多

EOS官方钱包keosd

EOS官方钱包的名称是keosd,它负责管理你的私钥,并且帮你进行交易的签名。 不过不幸的是,keosd钱包对普通用户并不友好,它是一个命令行程序,目前还没有像以太坊的mist那样的图形化界面,而...

汇智网教程
今天
28
0
ArrayList的实现原理以及实现线程安全

一、ArrayList概述 ArrayList是基于数组实现的,是一个动态的数字,可以自动扩容。 ArrayList不是线程安全的,效率比较高,只能用于单线程的环境中,在多线程环境中可以使用Collections.syn...

一看就喷亏的小猿
今天
36
0
Netty 备录 (一)

入职新公司不久,修修补补1个月的bug,来了点实战性的技术---基于netty即时通信 还好之前对socket有所使用及了解,入手netty应该不是很难吧,好吧,的确有点难,刚看这玩意的时候,可能都不知道哪里...

_大侠__
昨天
42
0
Django简单介绍和用户访问流程

Python下有许多款不同的 Web 框架。Django是重量级选手中最有代表性的一位。许多成功的网站和APP都基于Django。 Django是一个开放源代码的Web应用框架,由Python写成。 Django遵守BSD版权,初...

枫叶云
昨天
54
0
Spring Cloud Stream消费失败后的处理策略(四):重新入队(RabbitMQ)

应用场景 之前我们已经通过《Spring Cloud Stream消费失败后的处理策略(一):自动重试》一文介绍了Spring Cloud Stream默认的消息重试功能。本文将介绍RabbitMQ的binder提供的另外一种重试...

程序猿DD
昨天
25
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部