工作中Nginx经常被用来做负载均衡,负载均衡其意思就是分发请求到不同后端服务器,而不是指着一个人使劲用。当有2台或以上服务器时,根据设置的规则将请求分发到相应的服务器上处理,负载均衡配置一般都需要同时配置反向代理,通过反向代理跳转到负载均衡。而Nginx目前支持自带3种负载均衡策略,还有2种常用的第三方策略。
负载均衡通过upstream指令来实现。
1. RR(round robin :轮询 默认的负载均衡策略):
将接收到的请求按顺序循环的轮询下去,服务器接收请求的比例是 1:1,
如果某后端服务器挂掉,会自动剔除。
同一个项目分别使用10111和10112端口启动项目
upstream web_servers {
server localhost:10111;
server localhost:10112;
}
server {
listen 80;
server_name localhost;
#access_log logs/host.access.log main;
location / {
proxy_pass http://web_servers;
# 必须指定Header Host
proxy_set_header Host $host:$server_port;
}
}
2. 权重
权重分配实际就是按指定比例分配,就好股票占比一样;
指定轮询几率,服务器接收请求的比例就是各自配置的weight的比例,后端服务器性能不均时根绝各自服务器性能设置权重值;
upstream test {
server localhost:10111 weight=1;
server localhost:10112 weight=3;
server localhost:10113 weight=4 backup;
}
示例是4次请求只有一次被分配到10111上,其他3次分配到10112上。backup是指热备,只有当10111和10112都宕机的情况下才走10113.
3. ip_hash
上面的2种方式都有一个问题,那就是下一个请求来的时候请求可能分发到另外一个服务器,当我们的程序不是无状态的时候(采用了session保存数据),这时候就有一个很大的很问题了,比如把登录信息保存到了session中,那么跳转到另外一台服务器的时候就需要重新登录了,所以很多时候我们需要一个客户只访问一个服务器,那么就需要用iphash了,iphash的每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。
4. fair(第三方)
按服务器的响应时间来分配请求,响应时间短的优先分配。此配置能给与用户较快的响应;注意:使用第三方fair时,nginx需要添加fair模块,可以自行百度如何添加
upstream backend {
fair;
server localhost:10111;
server localhost:10112;
}
5. url_hash(第三方)
按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存时比较有效。在upstream中加入hash语句,server语句中不能写入weight等其他的参数,hash_method是使用的hash算法;
注意:需要安装第三方模块url_hash
upstream backend {
hash $request_uri;
hash_method crc32;
server localhost:10111;
server localhost:10112;
}
以上5种负载均衡适用不同情况下使用,可以根据实际情况选择使用哪种策略模式;