Browse Source

Store a count of the number of subproxies per proxy

master
Con Kolivas 10 years ago
parent
commit
d80393930d
  1. 4
      src/stratifier.c

4
src/stratifier.c

@ -319,6 +319,7 @@ struct proxy_base {
int64_t combined_clients; /* Total clients of all subproxies of a parent proxy */ int64_t combined_clients; /* Total clients of all subproxies of a parent proxy */
int64_t headroom; /* Temporary variable when calculating how many more clients can bind */ int64_t headroom; /* Temporary variable when calculating how many more clients can bind */
int subproxy_count; /* Number of subproxies */
proxy_t *parent; /* Parent proxy of each subproxy */ proxy_t *parent; /* Parent proxy of each subproxy */
proxy_t *subproxies; /* Hashlist of subproxies sorted by subid */ proxy_t *subproxies; /* Hashlist of subproxies sorted by subid */
sdata_t *sdata; /* Unique stratifer data for each subproxy */ sdata_t *sdata; /* Unique stratifer data for each subproxy */
@ -1046,6 +1047,7 @@ static proxy_t *__generate_proxy(sdata_t *sdata, const int64_t id)
proxy->sdata->verbose = true; proxy->sdata->verbose = true;
/* subid == 0 on parent proxy */ /* subid == 0 on parent proxy */
HASH_ADD(sh, proxy->subproxies, subid, sizeof(int), proxy); HASH_ADD(sh, proxy->subproxies, subid, sizeof(int), proxy);
proxy->subproxy_count++;
HASH_ADD_I64(sdata->proxies, id, proxy); HASH_ADD_I64(sdata->proxies, id, proxy);
sdata->proxy_count++; sdata->proxy_count++;
return proxy; return proxy;
@ -1060,6 +1062,7 @@ static proxy_t *__generate_subproxy(sdata_t *sdata, proxy_t *proxy, const int su
subproxy->low_id = proxy->low_id; subproxy->low_id = proxy->low_id;
subproxy->subid = subid; subproxy->subid = subid;
HASH_ADD(sh, proxy->subproxies, subid, sizeof(int), subproxy); HASH_ADD(sh, proxy->subproxies, subid, sizeof(int), subproxy);
proxy->subproxy_count++;
subproxy->sdata = duplicate_sdata(sdata); subproxy->sdata = duplicate_sdata(sdata);
subproxy->sdata->subproxy = subproxy; subproxy->sdata->subproxy = subproxy;
return subproxy; return subproxy;
@ -1567,6 +1570,7 @@ static void reap_proxies(ckpool_t *ckp, sdata_t *sdata)
} }
dead++; dead++;
HASH_DELETE(sh, proxy->subproxies, subproxy); HASH_DELETE(sh, proxy->subproxies, subproxy);
proxy->subproxy_count--;
free_proxy(subproxy); free_proxy(subproxy);
} }
} }

Loading…
Cancel
Save