Skip to content

Commit

Permalink
Fix missing locking when using mod_proxy_balancer
Browse files Browse the repository at this point in the history
ref #235
  • Loading branch information
jajik committed Dec 5, 2024
1 parent c5189da commit 5ac0d88
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 3 deletions.
4 changes: 4 additions & 0 deletions native/balancers/mod_lbmethod_cluster.c
Original file line number Diff line number Diff line change
Expand Up @@ -106,7 +106,9 @@ static proxy_worker *find_best(proxy_balancer *balancer, request_rec *r)
node_table = read_node_table(r->pool, node_storage, 0);
}

node_storage->lock_nodes();
mycandidate = internal_find_best_byrequests(r, balancer, vhost_table, context_table, node_table);
node_storage->unlock_nodes();

return mycandidate;
}
Expand Down Expand Up @@ -334,7 +336,9 @@ static apr_status_t mc_watchdog_callback(int state, void *data, apr_pool_t *pool
}

/* cleanup removed node in shared memory */
node_storage->lock_nodes();
remove_removed_node(s, pool, now, node_table);
node_storage->unlock_nodes();
}
break;

Expand Down
10 changes: 7 additions & 3 deletions native/mod_manager/mod_manager.c
Original file line number Diff line number Diff line change
Expand Up @@ -934,6 +934,7 @@ static int is_same_worker_existing(const request_rec *r, const nodeinfo_t *node)
static apr_status_t mod_manager_manage_worker(request_rec *r, const nodeinfo_t *node, const balancerinfo_t *bal)
{
apr_table_t *params;
apr_status_t rv;
kv_list_t *curr = proxyhctemplate;
params = apr_table_make(r->pool, 10);
/* balancer */
Expand All @@ -947,7 +948,10 @@ static apr_status_t mod_manager_manage_worker(request_rec *r, const nodeinfo_t *
apr_table_set(params, "b_wyes", "1");
apr_table_set(params, "b_nwrkr",
apr_pstrcat(r->pool, node->mess.Type, "://", node->mess.Host, ":", node->mess.Port, NULL));
balancer_manage(r, params);
rv = balancer_manage(r, params);
if (rv != APR_SUCCESS) {
return rv;
}
apr_table_clear(params);

/* now process the worker */
Expand Down Expand Up @@ -1582,14 +1586,14 @@ static char *process_config(request_rec *r, char **ptr, int *errtype)
/* Insert the Alias and corresponding Context */
phost = vhost;
if (phost->host == NULL && phost->context == NULL) {
loc_unlock_nodes();
/* if using mod_balancer create or update the worker */
if (balancer_manage) {
apr_status_t rv = mod_manager_manage_worker(r, &nodeinfo, &balancerinfo);
ap_log_error(APLOG_MARK, APLOG_DEBUG, 0, r->server, "process_config: balancer-manager returned %d", rv);
} else {
ap_log_error(APLOG_MARK, APLOG_DEBUG, 0, r->server, "process_config: NO balancer-manager");
}
loc_unlock_nodes();
return NULL; /* Alias and Context missing */
}
while (phost) {
Expand All @@ -1604,7 +1608,6 @@ static char *process_config(request_rec *r, char **ptr, int *errtype)
phost = phost->next;
vid++;
}
loc_unlock_nodes();

/* if using mod_balancer create or update the worker */
if (balancer_manage) {
Expand All @@ -1613,6 +1616,7 @@ static char *process_config(request_rec *r, char **ptr, int *errtype)
} else {
ap_log_error(APLOG_MARK, APLOG_DEBUG, 0, r->server, "process_config: NO balancer-manager");
}
loc_unlock_nodes();

ap_log_error(APLOG_MARK, APLOG_DEBUG, 0, r->server, "process_config: Done");

Expand Down

0 comments on commit 5ac0d88

Please sign in to comment.