使用URL参数通过HAProxy进行负载平衡


9

我有一个通过Cookie进行负载平衡的系统,但是我想使用URL参数作为替代。(特别是,我有一个不支持cookie的前端应用程序)。我的设置有点复杂-我有一个多人游戏系统,并且使用带有此cookie的棍子桌来确保玩同一游戏的不同人进入同一服务器。这很有效,除了URL参数似乎没有任何作用。这就是haproxy 1.5dev17的全部

我相关的后端是:

defaults
   log            global
   mode           http
   option         httplog
   option         dontlognull
   retries        3
   option         redispatch
   option         http-server-close

   maxconn        2000
   contimeout     5000
   clitimeout     50000
   srvtimeout     50000

backend simulate
    option httpchk OPTIONS /simulate/api/status
    stick-table type string len 40 size 5M expire 30m
    stick store-response set-cookie(SIMULATE_STICKY_SESSION) table simulate
    stick on cookie(SIMULATE_STICKY_SESSION) table simulate
    stick on url_param(SIMULATE_STICKY_SESSION) table simulate

    server app1 10.0.2.11:8080  cookie app1 check inter 10000
    server app2 10.0.3.11:8080  cookie app2 check inter 10000

请注意,SIMULATE_STICKY_SESSION由我的应用程序生成(基于玩家团队)。

当我调用URL时,我需要传递一个jsessionid(以便Tomcat找到正确的会话)。所以我在做

http://my.domain.com/myapp/url;SIMULATE_STICKY_SESSION=1918C909D3F30DB09C2F96B75C57D015.app1+jsessionid;jsessionid=1918C909D3F30DB09C2F96B75C57D015.app1

这似乎并没有像在错误服务器上使用粘性会话参数的50%一样。我尝试将param用作查询字符串(在?标记后),但这也不起作用。我究竟做错了什么?

Answers:


3

在haproxy邮件列表中提供了答复

摘抄

只需将您配置中的以下行更新为:

 stick on url_param(SIMULATE_STICKY_SESSION,;) table simulate

默认情况下,url_param在问号(?)之后搜索参数。上面的配置通过在分号(;)中查找cookie来覆盖此设置。

注意:您必须运行最新的1.5dev haproxy,最好是dev 18。


如用户列表中所述,答案是将行更改为:粘贴在url_param(SIMULATE_STICKY_SESSION ,;)表上
Will Glass
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.