Nginx upstream 的5种权重分配方式


1.轮询

upstream backend {
  server 192.168.0.14;
  server 192.168.0.15;
}

2.weight
指定轮询几率,weight 和访问比率成正比,用于后端服务器性能不均的情况。

upstream backend {
  server 192.168.0.14 weight=10;
  server 192.168.0.15 weight=10;
}

3.ip_hash
每个请求按访问 ip 的 hash 结果分配,这样每个访客固定访问一个后端服务器,可以解决 session 的问题。

upstream backend {
  ip_hash;
  server 192.168.0.14:88;
  server 192.168.0.15:80;
}

4.fair
按后端服务器的响应时间来分配请求,响应时间短的优先分配。

upstream backend {
  server server1.linuxany.com;
  server server2.linuxany.com;
  fair;
}

5.url_hash
按访问 url 的 hash 结果来分配请求,使每个 url 定向到同一个后端服务器,后端服务器为缓存时比较有效。

upstream backend {
  server squid1:3128;
  server squid2:3128;
  hash $request_uri;
  hash_method crc32;
}
阅读全文