MINOR: server: use the tree to look up the server name in findserver()

Let's just use the tree-based lookup instead of walking through the list.
This function is used to find duplicates in "track" statements and a few
such places, so it's important not to waste too much time on large setups.
This commit is contained in:
Willy Tarreau 2025-07-10 11:06:41 +02:00
parent 12a6a3bb3f
commit 5e78ab33cd
2 changed files with 6 additions and 9 deletions

View File

@ -61,7 +61,7 @@ const char *srv_update_check_addr_port(struct server *s, const char *addr, const
const char *srv_update_agent_addr_port(struct server *s, const char *addr, const char *port);
struct server *server_find_by_id(struct proxy *bk, int id);
struct server *server_find_by_id_unique(struct proxy *bk, int id, uint32_t rid);
struct server *findserver(const struct proxy *px, const char *name);
struct server *findserver(struct proxy *px, const char *name);
struct server *server_find_by_name(struct proxy *bk, const char *name);
struct server *server_find_by_name_unique(struct proxy *bk, const char *name, uint32_t rid);
struct server *server_find_best_match(struct proxy *bk, char *name, int id, int *diff);

View File

@ -4006,22 +4006,19 @@ struct server *server_find_by_id_unique(struct proxy *bk, int id, uint32_t rid)
* This function returns the server with a matching name within selected proxy,
* or NULL if not found.
*/
struct server *findserver(const struct proxy *px, const char *name)
struct server *findserver(struct proxy *px, const char *name)
{
struct ebpt_node *node;
struct server *cursrv;
if (!px)
return NULL;
for (cursrv = px->srv; cursrv; cursrv = cursrv->next) {
if (strcmp(cursrv->id, name) == 0)
node = ebis_lookup(&px->conf.used_server_name, name);
cursrv = node ? container_of(node, struct server, conf.name) : NULL;
return cursrv;
}
return NULL;
}
/* Returns a pointer to the first server matching either name <name>, or id
* if <name> starts with a '#'. NULL is returned if no match is found.
* the lookup is performed in the backend <bk>