nginx作反向代理时,提供了多种路由策略来决定请求该路由到哪一个后端节点。有轮询,最少连接,ip_hash,hash,sticky等。
1.weighted round-robin balancing(基于权重的轮询策略)
默认情况下nginx采用的轮询策略。
upstream backend {
server backend1.example.com weight=3;
server 127.0.0.1:8080 max_fails=3 fail_timeout=30s;
server 127.0.0.1:8081
}
如上面3个后端服务权重占比为 3:1:1,意味着每5个请求,3个分给第一个,其他2个server 各一个
2. least_conn(最少连接数)
将请求转发给连接数最少的后端服务
upstream backend {
least_conn;
server backend1.example.com ;
server 127.0.0.1:8080 max_fails=3 fail_timeout=30s;
server 127.0.0.1:8081
}
3. ip_hash(基于客户端ip 进行hash)
根据客户端ip进行hash计算得到对应的后端节点,将请求路由至该节点。
但是如果有多级nginx代理,或者其他特殊的网络拓扑结构,有可能造成资源利用不重复,请求都路由到单个节