haproxy的算法——混合算法

1.简介

混合算法即可作为静态算法,也可通过选项作为动态算法

算法 核心依据 核心优势 典型适用场景 注意事项
source 客户端源 IP 地址 实现简单,保证同一客户端请求固定到一台服务器 - 电商网站的用户会话保持- 后台管理系统的登录态 同一 NAT 出口的多个用户会被视为同一来源,可能导致负载不均
uri 请求的 URI 路径 提升缓存命中率,避免资源重复计算 - 静态资源服务(图片、CSS、JS)- CDN 节点调度 URI 频繁变化或资源分布不均时,可能导致负载倾斜
url_param URL 中指定的查询参数(如 user_id 可按业务维度实现更精细的粘性调度 - 按用户 ID 分区的用户服务- 按会话 ID 保持的长连接应用 参数值分布不均时,可能导致部分服务器负载过高
hdr HTTP 请求头中的指定字段(如 X-User-ID 策略灵活,可按域名、用户标识等复杂维度路由 - 多租户 SaaS 平台(按 Host 头区分)- 按用户标识分区的微服务架构 依赖请求头的完整性和一致性,需确保客户端或网关正确传递字段

2.source算法

source 算法基于客户端的源 IP 地址进行哈希计算,将同一 IP 的请求始终转发到同一台后端服务器。它能保证来自同一客户端的会话粘性,避免因服务器切换导致的会话丢失,适合需要保持会话状态的应用(如登录态、购物车),同时在后端服务器增减时可通过一致性哈希减少请求重定向的范围。source一般默认静态算法。

实验一:source静态算法

进入haproxy配置文件编写命令,保存退出,重启生效

测试:

实验二:source动态算法

在实验一的修改内容基础上添加一段命令:hash-type consistent(哈希形式 一次性),保存退出,重启生效

测试:

3.uri算法

uri 算法根据请求的 URI 路径进行哈希调度,确保对同一资源路径的请求始终落到同一台服务器上。这对缓存类服务(如静态资源、CDN 节点)非常友好,能提升缓存命中率,减少重复计算和资源加载,但在 URI 频繁变化或资源分布极不均匀的场景下,可能导致部分服务器负载过高。

主备uri动态算法实验环境

设定uri算法

测试:访问的文件不同

4.url_param算法

url_param 算法提取 URL 中指定的查询参数(如user-id、session-id)进行哈希,将带有相同参数值的请求转发到同一台服务器。它比 source 算法更精细,可按业务维度(如用户 ID)实现会话粘性,适合按用户或业务标识进行分区处理的场景。

主备url_param动态算法实验环境

设定url_param算法

这里的<name>就是你要提取的 URL 查询参数名,比如user_id、session_id、product_id等。

haproxy 会从请求的 URL 中提取这个参数的值,然后对这个值进行哈希计算,从而决定将请求转发到哪台后端服务器。

测试:name=的后面只能包含 字母(a-z/A-Z)、数字(0-9)、下划线(_)、连字符(-),这是 URL 查询参数名的通用规范

5.hdr算法

hdr 算法基于 HTTP 请求头中的指定字段(如Host、X-User-ID)进行哈希调度,能根据请求头信息实现更灵活的分区策略,例如按域名、用户标识或设备类型分配到不同服务器组,适合多租户、多业务线或需要精细化路由的复杂架构。

主备hdr动态算法实验环境

测试:分配结果由对 User-Agent 完整内容进行哈希计算后的值决定。只要内容相同,无论长度如何,都会分配到同一台服务器;内容不同,即使长度和奇偶性相同,也可能分配到不同的服务器。

相关推荐
杰克崔9 小时前
preempt_count()、in_interrupt()等上下文判断常用函数及宏介绍
linux·运维·服务器·车载系统
挠头猴子9 小时前
一个数组去重,两个数组找不同或相同
数据结构·算法
智能运维指南9 小时前
信创背景下,国产 DevOps 平台如何实现真正的“全栈适配”?
运维·devops
代码派9 小时前
NineData社区版:免费+本地化部署,满足数据库DevOps、数据复制与一致性对比的数据库管理平台
运维·数据库·database·devops·数据库管理工具·ninedata·数据库迁移
生活很暖很治愈9 小时前
Linux——TCP通信
linux·运维·tcp/ip
big_rabbit05029 小时前
[算法][力扣167]Two Sum II
算法·leetcode·职场和发展
开开心心就好9 小时前
小巧绿色免费关机工具,支持定时倒计时
linux·运维·服务器·安全·powerpoint·1024程序员节·foxmail
卢傢蕊9 小时前
LNAMP 网站架构与部署
运维·nginx·lamp
颜酱9 小时前
二分图核心原理与判定算法
javascript·后端·算法
筱砚.10 小时前
C++——lambda
开发语言·c++·算法