Hue Load Balance配置

个人博客地址:Hue Load Balance配置 | 一张假钞的真实世界

直接上配置:

复制代码
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策略,这个策略存在两个重要的问题:

  • 对隐藏在局域网后的用户不起作用。
  • ip_hash只取IPV4的前三段值做Hash,在非公网大并发场景下会出现负载非常不均衡的情况。参见:Module ngx_http_upstream_module

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

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

相关推荐
HXhlx5 小时前
CART决策树基本原理
算法·机器学习
Wect6 小时前
LeetCode 210. 课程表 II 题解:Kahn算法+DFS 双解法精讲
前端·算法·typescript
颜酱6 小时前
单调队列:滑动窗口极值问题的最优解(通用模板版)
javascript·后端·算法
闲云一鹤7 小时前
nginx 快速入门教程 - 写给前端的你
前端·nginx·前端工程化
Gorway13 小时前
解析残差网络 (ResNet)
算法
拖拉斯旋风13 小时前
LeetCode 经典算法题解析:优先队列与广度优先搜索的巧妙应用
算法
Wect13 小时前
LeetCode 207. 课程表:两种解法(BFS+DFS)详细解析
前端·算法·typescript
灵感__idea1 天前
Hello 算法:众里寻她千“百度”
前端·javascript·算法
Wect2 天前
LeetCode 130. 被围绕的区域:两种解法详解(BFS/DFS)
前端·算法·typescript
NAGNIP2 天前
一文搞懂深度学习中的通用逼近定理!
人工智能·算法·面试