http://blog.csdn.net/psy1100/article/details/71081348?utm_source=itdadao&utm_medium=referral
最近看了一些nginx做负载均衡的文章,在这里留下笔记,方便以后再次学习查看。
不喜勿喷
如果Nginx没有仅仅只能代理一台服务器的话,那它也不可能像今天这么火,Nginx可以配置代理多台服务器,当一台服务器宕机之后,仍能保持系统可用。具体配置过程如下:
1.
在http节点下,添加upstream节点。
upstream
linuxidc {
server
10.0.6.108:7080;
server
10.0.0.85:8980;
}
2. 将server节点下的location节点中的proxy_pass配置为:http:// +
upstream名称,即“
http://linuxidc”.
location
/ {
root
html;
index
index.html index.htm;
proxy_pass
http://linuxidc;
}
3.
现在负载均衡初步完成了。upstream按照轮询(默认)方式进行负载,每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。虽然这种方式简便、成本低廉。但缺点是:可靠性低和负载分配不均衡。适用于图片服务器集群和纯静态页面服务器集群。
除此之外,upstream还有其它的分配策略,分别如下:
weight(权重)
指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。如下所示,10.0.0.88的访问比率要比10.0.0.77的访问比率高一倍。
upstream
linuxidc{
server 10.0.0.77
weight=5;
server 10.0.0.88
weight=10;
}
ip_hash(访问ip)
每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。
upstream
favresin{
ip_hash;
server
10.0.0.10:8080;
server
10.0.0.11:8080;
}
fair(第三方)
按后端服务器的响应时间来分配请求,响应时间短的优先分配。与weight分配策略类似。
upstream
favresin{
server
10.0.0.10:8080;
server
10.0.0.11:8080;
fair;
}
url_hash(第三方)
按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存时比较有效。
注意:在upstream中加入hash语句,server语句中不能写入weight等其他的参数,hash_method是使用的hash算法。
upstream
resinserver{
server
10.0.0.10:7777;
server
10.0.0.11:8888;
hash
$request_uri;
hash_method
crc32;
}
upstream还可以为每个设备设置状态值,这些状态值的含义分别如下:
down
表示单前的server暂时不参与负载.
weight
默认为1.weight越大,负载的权重就越大。
max_fails
:允许请求失败的次数默认为1.当超过最大次数时,返回proxy_next_upstream 模块定义的错误.
fail_timeout :
max_fails次失败后,暂停的时间。
backup:
其它所有的非backup机器down或者忙的时候,请求backup机器。所以这台机器压力会最轻。
upstream
bakend{ #定义负载均衡设备的Ip及设备状态
ip_hash;
server 10.0.0.11:9090
down;
server 10.0.0.11:8080
weight=2;
server
10.0.0.11:6060;
server 10.0.0.11:7070
backup;
}
-----------------------------------
正向代理和反向代理:
![[转]nginx做负载均衡的几种方式 [转]nginx做负载均衡的几种方式]()