mirror of
https://git.haproxy.org/git/haproxy.git/
synced 2025-08-07 07:37:02 +02:00
BUG/MINOR: stick-table: insert srv in used_name tree even with fixed id
If the server id is fixed in the configuration, it is immediately inserted in the 'used_server_id' backend tree via srv_parse_id. On check_config_validity, the dynamic id generation is thus skipped for fixed-id servers. However, it must nevertheless be inserted in the 'used_server_name' backend tree. This bug seems to be not noticeable for the user. Indeed, before the fix, the search in sticking_rule_find_target always returned NULL for the name, then the fallback search with server id succeeded, so the persistence is properly applied. However with the fix the fallback search is not executed anymore, which saves from the locking of STK_SESS. This should be backported up to 2.0.
This commit is contained in:
parent
6916493c29
commit
077c6b8d29
@ -3496,9 +3496,10 @@ int check_config_validity()
|
||||
next_id = get_next_id(&curproxy->conf.used_server_id, next_id);
|
||||
newsrv->conf.id.key = newsrv->puid = next_id;
|
||||
eb32_insert(&curproxy->conf.used_server_id, &newsrv->conf.id);
|
||||
newsrv->conf.name.key = newsrv->id;
|
||||
ebis_insert(&curproxy->conf.used_server_name, &newsrv->conf.name);
|
||||
}
|
||||
newsrv->conf.name.key = newsrv->id;
|
||||
ebis_insert(&curproxy->conf.used_server_name, &newsrv->conf.name);
|
||||
|
||||
next_id++;
|
||||
newsrv = newsrv->next;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user