Usando parâmetros de URL para balanceamento de carga com HAProxy

9

Eu tenho um sistema que é o balanceamento de carga por meio de um cookie, mas desejo usar um parâmetro de URL como alternativa. (Especificamente, eu tenho um aplicativo front-end que não suporta cookies). Minha configuração é um pouco complexa - eu tenho um sistema multiplayer e eu uso uma mesa de pau com este cookie para garantir que pessoas diferentes jogando o mesmo jogo vão para o mesmo servidor. Isso funciona muito bem, exceto que os parâmetros de URL não parecem fazer nada. Isso é tudo com haproxy 1.5dev17

Meu back-end relevante é:

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

Observe que SIMULATE_STICKY_SESSION é gerado pelo meu aplicativo (com base na equipe do jogador).

Quando eu chamo o URL, preciso passar um jsessionid (para que o Tomcat encontre a sessão correta). Então estou fazendo

link

Isso não parece estar pegando o parâmetro de sessão fixo como 50% do tempo que vai para o servidor errado. Eu tentei usar o param como uma string de consulta (depois de uma? Marca), mas isso não funcionou também. O que estou fazendo errado?

    
por Will Glass 01.04.2013 / 10:19

1 resposta

3

Uma resposta foi fornecida aqui na lista de discussão haproxy

trecho

simply update the line below in your configuration to:

 stick on url_param(SIMULATE_STICKY_SESSION,;) table simulate

By default, url_param search for a parameter after the question mark (?). The configuration above overwrite this by looking for your cookie from the semi-colon (;).

Note: you must be running a recent 1.5dev haproxy, preferably the dev 18.

    
por 05.04.2013 / 08:19