什么是负载均衡?
当一台服务器的性能达到极限时,我们可以使用服务器集群来提高网站的整体性能。那么,在服务器集群中,需要有一台服务器充当调度者的角色,用户的所有请求都会首先由它接收,调度者再根据每台服务器的负载情况将请求分配给某一台后端服务器去处理。
下面简单介绍下在windows下通过在同一台机器上使用IIS创建两个站点,nginx做负载均衡:
1.首先在windows下安装iis服务:
安装流程如下:
控制面板->程序->打开或关闭Windows功能,打开后会出现如下图:
点击确定安装。
成功后再次打开控制面板->管理工具;
打开后会出现iis管理界面。创建两个站点:
2.nginx与iis的默认端口都是80,这里使用nginx做负载均衡,所以需要改变iis的默认端口,这里我把IIS的默认端口改成了81
测试域名test_one.com
A站点:默认站点
B站点:127.0.0.1:9001
c站点:127.0.0.1:9002
当我们访问test_one.com,由A负载到B或c
3.配置nginx.conf文件
打开conf文件,在http中添加:
upstream test_one.com {
server 127.0.0.1:9001;
server 127.0.0.1:9002;
}
server{
listen 80;
server_name localhost;
location / {
proxy_pass http://test_one.com;
}
保存重启nginx
4.测试
访问www.test_one.com,为了区分站点访问,分别在B和C中添加index.html文件内容不同就行。
打开后运行结果:
注意:
1.负载均衡不是nginx独有,apache,IIS也可以实现负载均衡,但性能可能不如nginx。
2.多台服务器提供服务,但域名只解析到主服务器,而真正的服务器IP不会被ping下即可获得,增加一定安全性。
3.upstream里的IP不一定是内网,外网IP也可以。不过经典的案例是,局域网中某台IP暴露在外网下,域名直接解析到此IP。然后又这台主服务器转发到内网服务器IP中。
4.某个站点无法访问、不会影响网站正常运行,Nginx不会把请求转发到已停止的站点