您的位置:首页 > 运维架构 > Nginx

采用软件nginx实现web服务器集群

2014-05-03 08:45 447 查看
nginx:软件负载均衡器 是高并发量http/反向代理服务器。实现windows下IIS的负载均衡

条件:2台服务器

1、cpu:Inter(R) 酷睿 i5 cpu 2.26GHz

内存:2G

系统:windows 7

IIS:IIS 7

nginx:nginx/windows-1.2.7

IP:192.168.2.123

环境:本地

2、cpu:Inter(R) 酷睿 i3 cpu 2.13GHz

内存:2G

系统:windows server 2003

IIS:IIS 6

nginx:nginx/windows-1.2.7

IP:192.168.2.124

环境:本地
注意:本次测试,软件nginx放在本地(192.168.2.123),也就是说放在域名绑定的那台服务器,这台服务器的IIS不能使用80端口,

因为等下nginx软件要使用80端口。

下载nginx的地址如下:

nginx下载:http://nginx.net/

本次测试使用的软件版本是:nginx/windows-1.2.7

下载解压到C:,把目录名改成nginx

实现步骤:
1、在本地192.168.2.123这台服务器IIS创建一个网站,使用端口号为8088。在远程192.168.2.124这台服务器IIS创建一个网站,使用端口号为8088。
两个网站都绑定相同的网站程序。
2、上面设置好两台web服务器的IIS后,下面配置nginx软件来做负载均衡集群。

打开C:\nginx\conf\nginx.conf

1.找到内容server{,在它的上面加入如下内容:

upstream ym.com{

server 192.168.2.123:8088;#真实服务器A(ym-PC)

server 192.168.2.124:8088;#真实服务器B(ym-PC)

}

(该内容是:负载切换使用的服务器网站IP)

2.找到 location / {

root html;

index index.html index.htm;

}

把内容替换成如下: location / {

proxy_pass http://ym.com;
proxy_redirect default;

}

3.找到server{

listen 80;

server_name localhost;

}

把内容替换成如下:

server{#Nginx代理服务器

listen 80;

server_name 192.168.2.26;

}

可参考下面的配置操作:

worker_processes  1;

events {
worker_connections  1024;
}

http {
include       mime.types;
default_type  application/octet-stream;
sendfile        on;
keepalive_timeout  65;

upstream wgf.com{
server 192.168.1.98;    #真实服务器A(sxwgf-PC)
server 192.168.1.99;    #真实服务器B(hzdk-vpc)
}

server {    #Nginx代理服务器
listen       8088;

server_name  localhost;

location / {
root   html;
index  index.html index.htm;
proxy_pass  http://wgf.com; proxy_redirect  default;
}

error_page   500 502 503 504  /50x.html;
location = /50x.html {
root   html;
}

}
}


(这是监听访问域名所绑定的那台服务器的80端口的请求)

4.上述已经配置好了负载均衡。接下来就启动nginx软件,

进入命令提示符CMD,进入c:\nginx,输入nginx命令就可以运行。

停止nginx运行,输入nginx -s stop 即可

5.经过以上配置,现在就可以看下负载效果了。
在本地192.168.2.123这台服务器打开浏览器,输入http://192.168.2.123/,不断刷新,会不断把请求负载到两台服务器上。这样,网站的负载就成功了。
官方说nginx的并发数是50000,实际生产中是30000左右比较稳定。如果网站访问量非常大,可以专门用一台高配置的服务器跑nginx,其他web服务器跑
网站程序,如此负载,就没有太大问题,如果再不行,把网站的一些功能栏目做一个2级域名,2级域名同样做负载,这样就更强了。

nginx软件在linux上跑,性能比在windows上跑要好,所以做负载均衡的服务器,最好用linux跑nginx,而.net开发的网站放到windows服务器的IIS上。

注意:1、找到本地机器的\WINDOWS\system32\drivers\etc,修改hosts文件,添加192.168.2.123 www.ym123.com 注释掉#host

2、找到远程机器的\WINDOWS\system32\drivers\etc,修改hosts文件,添加192.168.2.124 www.ym123.com

3、

upstream ym.com{

server 192.168.2.123:8088;

server 192.168.2.124:8088;

}

server{#Nginx代理服务器

listen 80;

server_name http://www.ym123.com;
#charset koi8-r;

#access_log logs/host.access.log main;

location / {

proxy_pass http://ym.com/;
proxy_redirect default;

}

通过以上步骤,就可以使本地和远程机器通过域名访问做实验,避免实际域名的绑定。

/article/5322475.html


采用软件负载均衡器实现web服务器集群

我用nginx实现网站负载均衡测试的例子,windows下IIS做负载实测.

如果你的网站访问量(pv)越来越高,一台服务器已经没有办法承受流量压力,那就增多几台WEB服务器来做负载吧。
做网站负载可以买硬件设备来实现,我们公司用的是F5,不过价格就几十万到上百万,太贵了,
目前好多门户网站与大访问量的网站都在使用nginx做为HTTP服务器,所以nginx是非常优秀的,下面我亲手做这个负载测试吧。
软/硬件环境:

(2台服务器)

第一台:

CPU:Inter(R) 酷睿 i5 CPU 2.26GHz
内存:2G

系统:windows 7

IIS: IIS 7

nginx:nginx/Windows-0.8.22

IP:10.60.44.126

环境:本地

第二台:

CPU:Inter(R) 酷睿 i3 CPU 2.13GHz
内存:2G

系统:windows Server 2003

IIS: IIS 6

IP:10.60.44.127

环境:远程

注意:

本次测试,软件nginx放在本地(10.60.44.126),也就是说放在域名绑定的那台服务器,这台服务器的IIS不能使用80端口,因为等下nginx软件要使用80这个端口。

下载nginx的地址如下:

nginx下载:http://nginx.net/

本次测试使用的版本下载:nginx/Windows-0.8.22
下载解压到C:,把目录名改成nginx

实践步骤:
第一:
在本地(10.60.44.126)这台服务器IIS创建一个网站,使用端口为808,如下图:

IIS 网站绑定设置图
第二:
在远程10.60.44.127的IIS创建一个网站,使用端口为808,如下图:

远程IIS绑定设置图

注意:第一步和第二步绑定相同的网站程序!
第三:
好了,以上已经设置好两台服务器的IIS了,下面配置nginx软件来实现网站负载均衡器,打开如下文件:
C:\nginx\conf\nginx.conf
1、找到内容server {
在这上面加入如下内容:
upstream chenlu.com {

server 10.60.44.126:808;

server 10.60.44.127:808;

}
(这是负载切换使用的服务器网站IP)
2、找到location / {

root html;

index index.html index.htm;

}
把内容更改如下:
location / {

proxy_pass http://chenlu.com/;

proxy_redirect default;

}
3、找到server {

listen 80;

server_name localhost;
把内容改成如下:
server {

listen 80;

server_name 10.60.44.126;
(这是监听访问域名绑定那台服务器80端口的请求)
好,在这里就这么简单配置好了,下面看下以上3步配置的图:



负载均衡器配置图
第四:
都配置好了,下面启动nginx这软件
进入命令提示符CMD,进入c:\nginx>,输入nginx命令,如下图:


启动nginx
这时候,系统进程有两个nginx.exe进程,如下图:



系统nginx进程
停止nginx运行输入nginx -s stop 即可

第五:
经过以上的配置,现在我们看下负载效果:
在本地(10.60.44.126)这服务器打开IE,输入:http://10.60.44.126/
第一次打开网站的结果图:


第一次运行网站图
再刷新一下网页,出现的结果图:


再次访问网站图
很好,网站已经负载成功。(注意:此时页面中服务器名称已经更换)
经过这次测试,实现网站负载再也不是难事了。也不用购买非常贵的硬件设备了。网上介绍说nginx软件可以处理并发上万,所以绝对是个非常不错的选择。
如果网站访问量非常大,可以专门用一台服务器跑nginx,其它服务器跑网站程序(几台服务器的程序都是一样的),这样负载就没有太大问题,如果再不行,把网站一些栏目做一个2级域名,2级域名同样做负载,这样更厉害了吧。
nginx软件在linux上跑性能比在windows上跑要好,所以做负载可以用linux跑nginx,.net开发的网站放到windows服务器IIS上。

注意:
1找到本地机器的 \WINDOWS\system32\drivers\etc,修改hosts文件,添加10.60.44.126 www.chenlulouis123456.com
注释掉#host
2 找到远程机器的 \WINDOWS\system32\drivers\etc,修改hosts文件 10.60.44.127 www.chenlulouis123456.com
3.

upstream chenlu.com

{

server 10.60.44.126:808;

server 10.60.44.127:808;

}

server {

listen 80;

server_name http://www.chenlu123456.com/;
#charset koi8-r;
#access_log logs/host.access.log main;
location / {

proxy_pass http://chenlu.com/;

proxy_redirect default;

}
进过以上步骤,就可以使本地和远程机器通过域名访问做实验,避免实际域名绑定。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: