Hue Load Balance配置

直接上配置:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
server {
server_name 192.168.72.31;
listen 8001;

charset utf-8;

proxy_connect_timeout 600s;
proxy_read_timeout 600s;
proxy_send_timeout 600s;

location / {
proxy_set_header Host $http_x_forwarded_for;
proxy_set_header X-Forwarded-For $http_x_forwarded_for;

proxy_pass http://hue;
}
}

upstream hue {
hash $cookie_sessionid;

server 192.168.72.22:8888 max_fails=3;
server 192.168.72.31:8888 max_fails=3;
}

重点是调整upstream hash的策略。因为Hue是需要保持session的,同一个session的请求需要发送到同一台后端服务器上。简单的可以采用ip_hash策略,这个策略存在两个重要的问题:

基于以上两点修改了Nginx的配置采用$cookie_sessionid做为hash值,达到session级别的负载均衡。

主要的问题其实是这种方式未做到按照后端服务器实际负载再按照session级别来分配请求。后续打算研究HAProxy是否可以做到。