Hue Load Balance配置
直接上配置:
1 | server { |
重点是调整upstream hash
的策略。因为Hue是需要保持session的,同一个session的请求需要发送到同一台后端服务器上。简单的可以采用ip_hash策略,这个策略存在两个重要的问题:
- 对隐藏在局域网后的用户不起作用。
- ip_hash只取IPV4的前三段值做Hash,在非公网大并发场景下会出现负载非常不均衡的情况。参见:http://nginx.org/en/docs/http/ngx_http_upstream_module.html#ip_hash
基于以上两点修改了Nginx的配置采用$cookie_sessionid
做为hash值,达到session级别的负载均衡。
主要的问题其实是这种方式未做到按照后端服务器实际负载再按照session级别来分配请求。后续打算研究HAProxy是否可以做到。