用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的功能远不止此……