nginx的五种负载算法

nginx的五种负载算法

2017年04月26日 15:01:11nginx

阅读数:1297算法

1.round robin(默认)

轮询方式,依次将请求分配到各个后台服务器中,默认的负载均衡方式。 
适用于后台机器性能一致的状况。 
挂掉的机器能够自动从服务列表中剔除。后端

2.weight

根据权重来分发请求到不一样的机器中,指定轮询概率,weight和访问比率成正比,用于后端服务器性能不均的状况。  缓存

例如:  服务器

 

 
  1. upstream bakend { session

  2. server 192.168.0.14 weight=10; 负载均衡

  3. server 192.168.0.15 weight=10; post

  4. }性能


3.ip_hashui

 

根据请求者ip的hash值将请求发送到后台服务器中,能够保证来自同一ip的请求被打到固定的机器上,能够解决session问题。

例如:

 

 
  1. upstream bakend {

  2. ip_hash;

  3. server 192.168.0.14:88;

  4. server 192.168.0.15:80;

  5. }

 

 

4.url_hash(第三方)

根据请求的url的hash值将请求分到不一样的机器中,当后台服务器为缓存的时候效率高。

例如:

在upstream中加入hash语句,server语句中不能写入weight等其余的参数,hash_method是使用的hash算法  

 

 
  1. upstream backend {

  2. server squid1:3128;

  3. server squid2:3128;

  4. hash $request_uri;

  5. hash_method crc32;

  6. }


tips:  

 

 

 
  1. upstream bakend{#定义负载均衡设备的Ip及设备状态

  2. ip_hash;

  3. server 127.0.0.1:9090 down;

  4. server 127.0.0.1:8080 weight=2;

  5. server 127.0.0.1:6060;

  6. server 127.0.0.1:7070 backup;

  7. }

 

 

在须要使用负载均衡的server中增长  

 

proxy_pass http://bakend/;

 

 

每一个设备的状态设置为: 

1.down 表示单前的server暂时不参与负载  
2.weight 默认为1.weight越大,负载的权重就越大。  
3.max_fails :容许请求失败的次数默认为1.当超过最大次数时,返回proxy_next_upstream 模块定义的错误  
4.fail_timeout:max_fails次失败后,暂停的时间。  
5.backup: 其它全部的非backup机器down或者忙的时候,请求backup机器。因此这台机器压力会最轻。  
nginx支持同时设置多组的负载均衡,用来给不用的server来使用。  
client_body_in_file_only 设置为On 能够讲client post过来的数据记录到文件中用来作debug  
client_body_temp_path 设置记录文件的目录 能够设置最多3层目录  
location 对URL进行匹配.能够进行重定向或者进行新的代理 负载均衡

 

5.fair(第三方)

根据后台响应时间来分发请求,响应时间短的分发的请求多。

例如:

 

 
  1. upstream backend {

  2. server server1;

  3. server server2;

  4. fair;

  5. }

相关文章
相关标签/搜索