用Nginx搭建IIS集群实现负载均衡

长话短说,我们用Nginx来搭建一个简单的集群,实现Web应用的负载均衡,架构图如下:

 

 两台Web服务器,一台静态资源服务器,因为是演示,我们以网站形式部署在本机IIS中

一台Nginx代理服务器,安装到本机的Linux虚拟机中,参考 CentOS下Nginx安装与配置

 

网站部署

新建三个文件夹,用于网站部署

 在IIS中新建三个站点,分别指向以上三个目录,两台WEB端口是9527,9528,静态资源站点端口9529

新建两个HTML网页 index.html,内容分别是 This is localhost:9527 和 This is localhost:9528,发布到9527和9528网站下

<!DOCTYPE html>
<html lang="en-US">
<head>
    <title>test</title>
</head>
    <body>
        <h1>This is localhost:9527</h1>
        <img src="/images/cnblog.gif">
    </body>    
</html>

到9529网站下新建一个images文件夹,放入一张图片cnblog.gif

预览下这三个网站,都是OK的,9527和9528网站目录下没有cnblog图片,所以显示失败,后面图片将从资源服务器9529去取。

 

配置Nginx

在CentOS命令环境下,Nginx启动和停止的命令:

cd /usr/local/nginx/sbin/  进入Nginx运行目录
./nginx  启动
./nginx -s reload  重新加载配置
./nginx -s quit:   处理完毕后退出
./nginx -s stop:   强制杀掉Nginx进程

启动成功,在浏览器访问Nginx代理服务器IP(192.168.149.129)可以看到如下页面

 

下面来更改配置,用vi编辑器打开nginx.conf文件,配置服务器集群

upstream是配置集群,192.168.92.1是我本机的IP,weight是权重,9527的权重是1,9528的权重是2,访问比率是,Nginx会将请求转发给9527一次,然后转发给9528两次,如此轮询;

ip_hash:每个请求按访问ip的hash结果分配,这样每个访客固定访问一台Web服务器,可以解决session的问题,但是客户端IP也会变换,那这招就不好使,还是推荐用分布式缓存如Redis来保持session,这里把ip_hash注释掉了;

第一个location配置了默认请求转发给集群myserver,第二个请求是将指定文件的请求转发给本机的9529端口(资源服务器)

配置好后,保存退出,用 nginx -t 测试一下配置是否正常,没问题用 nginx -s reload 重新加载配置,直接运行

 

测试结果

在本机浏览器输入Nginx代理服务器IP(192.168.149.129)当前显示9527,刷新一下变成9528,刷新两下变回9527,图片也正常显示,一个网页分别从三台服务器取数据

 

 

现在我们停止9527这个站点(模拟某台服务器宕机了),再刷新网页

网站仍然正常浏览,只是一直是显示9528,这就是故障转移

 

大功告成,用Nginx很容易就实现了负载均衡,当然Nginx的功能远不止此……

 

posted @ 2017-09-02 18:39  felixnet  阅读(2191)  评论(3编辑  收藏  举报