gpt4 book ai didi

load-balancing - HAProxy stick-table 存储自定义值

转载 作者:行者123 更新时间:2023-12-04 17:36:41 25 4
gpt4 key购买 nike

我想在 stick-table 中存储自定义“值”,并在另一个 ACL 中使用它来选择服务器。

我有这个配置,它创建了以 header 值“x-external-id”作为键,以服务器 ID 作为其值的 stick-table。

frontend frontend
bind 125.213.51.144:8080
default_backend backend

backend backend
balance roundrobin
stick store-request req.hdr(x-external-id)
stick-table type string len 50 size 200k nopurge
server gw1 125.213.51.100:8080 check id 1
server gw2 125.213.51.101:8080 check id 2

这个配置产生了这个 stick 表:

# table: backend, type: string, size:204800, used:3
0x558955d52ac4: key=00000000000 use=0 exp=0 server_id=1
0x558955d53114: key=11111111111 use=0 exp=0 server_id=2
0x558955d87a34: key=22222222222 use=0 exp=0 server_id=2

值 (server-id) 由 HaProxy 根据处理请求的服务器设置。但我想在这里保存一个自定义值。可能吗?

最佳答案

显然 HAProxy 不允许存储自定义值。 stick表中只能存储server_id和tracking counters。

所以我定义了两个后端,每个后端有一个 stick table。每个客户端访问自己的后端并填充 stick 表。

从另一个 HAProxy 部分,我可以使用 table_server_id 在 stick 表中查找并路由到拥有具有该条目的 stick 表的后端。

############## Frontend ################
frontend my-frontend
bind 125.213.51.100:38989

acl is_service1 req.hdr(x-external-id),table_server_id(stick-table-1) -m int gt 0
use_backend my-backend if is_service1

acl is_service2 req.hdr(x-external-id),table_server_id(stick-table-2) -m int gt 0
use_backend my-backend-2 if is_service2

default_backend my-backend-default

############## Backend 1 ################
backend my-backend
balance roundrobin
server service1 125.213.51.100:18989 check id 1 inter 10s fall 1 rise 1
server service2 125.213.51.200:18989 check id 2 backup

############## Backend 2 ################
backend my-backend-2
balance roundrobin
server service2 125.213.51.100:18989 check id 2 inter 10s fall 1 rise 1
server service1 125.213.51.200:18989 check id 1 backup

############## Backend Default ################
backend my-backend-default
balance roundrobin
server service1 125.213.51.100:18989 check id 1
server service2 125.213.51.200:28989 check id 2

关于load-balancing - HAProxy stick-table 存储自定义值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56449073/

25 4 0