mirror of
https://gitlab.torproject.org/tpo/core/tor.git
synced 2024-11-10 21:23:58 +01:00
Add functions to extend and compress new router store logic. (Basic idea: use a journal of newly received router descriptors, and periodically replace the old file. This avoids the "too many files" problem and the "too many rewrites" problem.)
svn:r5025
This commit is contained in:
parent
d4fb1fcd6c
commit
29c57b54d4
@ -117,6 +117,103 @@ router_reload_networkstatus(void)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* DOCDOC */
|
||||||
|
static size_t router_log_len = 0;
|
||||||
|
static size_t router_store_len = 0;
|
||||||
|
|
||||||
|
/* DOCDOC */
|
||||||
|
static int
|
||||||
|
router_should_rebuild_store(void)
|
||||||
|
{
|
||||||
|
if (router_store_len > (1<<16))
|
||||||
|
return router_log_len > router_store_len / 2;
|
||||||
|
else
|
||||||
|
return router_log_len > (1<<15);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* DOCDOC */
|
||||||
|
int
|
||||||
|
router_append_to_log(const char *s, size_t len)
|
||||||
|
{
|
||||||
|
or_options_t *options = get_options();
|
||||||
|
size_t fname_len = strlen(options->DataDirectory)+32;
|
||||||
|
char *fname = tor_malloc(len);
|
||||||
|
|
||||||
|
tor_snprintf(fname, fname_len, "%s/cached-routers.log",
|
||||||
|
options->DataDirectory);
|
||||||
|
|
||||||
|
if (!len)
|
||||||
|
len = strlen(s);
|
||||||
|
|
||||||
|
if (append_bytes_to_file(fname, s, len, 0)) {
|
||||||
|
log_fn(LOG_WARN, "Unable to store router descriptor");
|
||||||
|
tor_free(fname);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
tor_free(fname);
|
||||||
|
router_log_len += len;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* DOCDOC */
|
||||||
|
int
|
||||||
|
router_rebuild_store(int force)
|
||||||
|
{
|
||||||
|
size_t len = 0;
|
||||||
|
or_options_t *options;
|
||||||
|
size_t fname_len;
|
||||||
|
smartlist_t *chunk_list = NULL;
|
||||||
|
char *fname = NULL;
|
||||||
|
int r = -1;
|
||||||
|
|
||||||
|
if (!force && !router_should_rebuild_store())
|
||||||
|
return 0;
|
||||||
|
if (!routerlist)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
options = get_options();
|
||||||
|
fname_len = strlen(options->DataDirectory)+32;
|
||||||
|
fname = tor_malloc(fname_len);
|
||||||
|
tor_snprintf(fname, fname_len, "%s/cached-routers", options->DataDirectory);
|
||||||
|
chunk_list = smartlist_create();
|
||||||
|
|
||||||
|
SMARTLIST_FOREACH(routerlist->routers, routerinfo_t *, ri,
|
||||||
|
{
|
||||||
|
sized_chunk_t *c;
|
||||||
|
if (!ri->signed_descriptor) {
|
||||||
|
log_fn(LOG_WARN, "Bug! No descriptor stored for router '%s'.",
|
||||||
|
ri->nickname);
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
c = tor_malloc(sizeof(sized_chunk_t));
|
||||||
|
c->bytes = ri->signed_descriptor;
|
||||||
|
c->len = ri->signed_descriptor_len;
|
||||||
|
smartlist_add(chunk_list, c);
|
||||||
|
});
|
||||||
|
|
||||||
|
if (write_chunks_to_file(fname, chunk_list, 0)<0) {
|
||||||
|
log_fn(LOG_WARN, "Error writing router store to disk.");
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
|
||||||
|
tor_snprintf(fname, fname_len, "%s/cached-routers.log",
|
||||||
|
options->DataDirectory);
|
||||||
|
|
||||||
|
write_str_to_file(fname, "", 0);
|
||||||
|
|
||||||
|
r = 0;
|
||||||
|
router_store_len = len;
|
||||||
|
router_log_len = 0;
|
||||||
|
done:
|
||||||
|
tor_free(fname);
|
||||||
|
if (chunk_list) {
|
||||||
|
SMARTLIST_FOREACH(chunk_list, sized_chunk_t *, c, tor_free(c));
|
||||||
|
smartlist_free(chunk_list);
|
||||||
|
}
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
/* Set *<b>outp</b> to a smartlist containing a list of
|
/* Set *<b>outp</b> to a smartlist containing a list of
|
||||||
* trusted_dir_server_t * for all known trusted dirservers. Callers
|
* trusted_dir_server_t * for all known trusted dirservers. Callers
|
||||||
* must not modify the list or its contents.
|
* must not modify the list or its contents.
|
||||||
|
Loading…
Reference in New Issue
Block a user