在nginx中,负载均衡策略主要由以下几种,轮询、加权轮询、ip_hash、least_conn、fair和url_hash。下面将分别介绍每一种。
轮询
每个请求按时间顺序,依次分配到不同的后端服务器。如果后端某台服务器宕机,故障系统被自动剔除,使用户访问不受影响。
1 | upstream backend { |
加权轮询
weight指定轮询的权值,weight值越大,分配到的访问机率越高,此策略主要用于后端每个服务器性能不均的情况下。
1 | upstream backend { |
ip_hash
每个请求按访问IP的hash结果分配,这样来自同一个IP的访客固定访问一个后端服务器,可以解决session不能跨服务器的问题。当然如果这个节点不可用了,会发到下个节点,而此时没有session同步的话就注销掉了。
1 | upstream backend { |
least_conn
请求被发送到当前活跃连接最少的后端服务器。会考虑weight的值。如果有多个后端服务器的Connection值同为最小的,那么对它们采用加权轮询算法(weight)。
1 | upstream backend { |
fair(upstream_fair模块)
根据后端服务器的响应时间来分配请求,响应时间短的优先分配。Nginx本身是不支持fair的,如果需要使用这种调度算法,必须下载Nginx的upstream_fair模块。
1 | upstream backend { |
url_hash(nginx _upstream_hash模块)
此方法按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,可以进一步提高后端缓存服务器的效率。Nginx本身是不支持url_hash的,如果需要使用这种调度算法,必须下载 Nginx 的 nginx_upstream_hash 模块。
1 | upstream backend { |
本篇文章只是简单的总结了nginx中的负载均衡,如果希望了解负载均衡的详细配置,可以看这篇文章
nginx之upstream(负载均衡)模块