zoukankan      html  css  js  c++  java
  • 用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的功能远不止此……

  • 相关阅读:
    js上传插件uploadify自动检测不到flash控件的问题
    记在VMware虚拟机中对网站进行性能压力测试的经历
    只因路不同 —— 我选择了做一个程序员
    基于DDD的.NET开发框架
    程序员为什么要时刻保持危机感?
    基于DDD的.NET开发框架
    基于DDD的.NET开发框架
    基于DDD的.NET开发框架
    一步一步学习ABP项目系列文章目录
    基于DDD的.NET开发框架
  • 原文地址:https://www.cnblogs.com/felixnet/p/7467294.html
Copyright © 2011-2022 走看看