ouzhoudijie 发表于 2017-12-27 22:06:24

用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>
./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>
  测试结果
  在本机浏览器输入Nginx代理服务器IP(192.168.149.129)当前显示9527,刷新一下变成9528,刷新两下变回9527,图片也正常显示,一个网页分别从三台服务器取数据

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

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

  大功告成,用Nginx很容易就实现了负载均衡,当然Nginx的功能远不止此……
页: [1]
查看完整版本: 用Nginx搭建IIS集群实现负载均衡