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是否可以做到。

相关推荐
阿鼎08152 分钟前
揭秘大语言模型:从文字到数字,token 是如何变成向量的?
人工智能·算法
GeekPMAlex4 分钟前
Conetext learning 3 KV-cache的提升
算法
找不到、了1 小时前
Java排序算法之<选择排序>
数据结构·算法·排序算法
是店小二呀2 小时前
【动态规划-斐波那契数列模型】理解动态规划:斐波那契数列的递推模型
算法·动态规划·代理模式
小徐不徐说2 小时前
动态规划:从入门到精通
数据结构·c++·算法·leetcode·动态规划·代理模式
guguhaohao2 小时前
排序算法,咕咕咕
数据结构·算法·排序算法
小新学习屋2 小时前
《剑指offer》-数据结构篇-树
数据结构·算法·leetcode
好心的小明2 小时前
【深度之眼机器学习笔记】04-01-决策树简介、熵,04-02-条件熵及计算举例,04-03-信息增益、ID3算法
笔记·算法·决策树
恣艺4 小时前
LeetCode 1074:元素和为目标值的子矩阵数量
算法·leetcode·矩阵
queenlll5 小时前
P1064 [NOIP 2006 提高组] 金明的预算方案 题解
算法