HAProxy:防止粘性到备份服务器

Flo*_*Flo 3 haproxy

我面临 HAProxy (1.8) 的配置问题。

语境:

  • 在 HAProxy 配置中,我在后端有几台服务器,还有一个额外的备份服务器,以防其他服务器出现故障。
  • 一旦客户端从服务器获得答案,它必须坚持到该服务器进行下一个查询。
  • 由于某些充分的原因,我不能使用 cookie 来解决这个问题,而我不得不使用粘表。

问题:

  • 当每个“正常”服务器关闭时,客户端将按预期重定向到备份服务器。
  • 但棒表随后会填充客户端和备份服务器 ID 之间的关联。
  • 并且当每个“正常”服务器恢复时,棒表中存在的并与备份服务器的 ID 相关联的客户端将继续重定向到备份服务器,而不是正常的服务器!

这实在是让我很不爽……

所以我的问题是:如何防止 HAProxy 将客户端粘到后端的备份服务器上?

请在下面找到配置示例:

defaults
  option redispatch

frontend fe_test
  bind 127.0.0.1:8081
  stick-table type ip size 1m expire 1h
  acl acl_test  hdr(host) -i whatever.domain.com
  ...
  use_backend be_test if acl_test
  ...

backend be_test
  mode http
  balance roundrobin
  stick on hdr(X-Real-IP) table fe_test
  option httpchk GET /check
  server test-01 server-01.lan:8080 check
  server test-02 server-02.lan:8080 check
  server maintenance 127.0.0.1:8085 backup
Run Code Online (Sandbox Code Playgroud)

(我已经尝试为备份服务器添加较低的权重,但它没有解决这个问题。)

我在文档中读到“stick-on”关键字有一些“if/unless”选项,也许我可以用它来根据后端服务器名称编写条件,但我不知道要使用的语法,或者即使有可能。

欢迎任何想法!

Flo*_*Flo 6

我真是太傻了!我对粘表配置非常着迷,以至于我没有想到查看服务器选项......

有一个简单的关键词就完美解决了我的问题:不粘

切勿将分配给该服务器的连接添加到棒表中。这可以与备份结合使用,以确保备份服务器禁用棒表持久性。

所以我的配置示例的最后一行就变成了:

server maintenance 127.0.0.1:8085 backup non-stick
Run Code Online (Sandbox Code Playgroud)

...现在一切都按我的预期进行。