[or-cvs] Add functions to extend and compress new router store logic...
Nick Mathewson
nickm at seul.org
Tue Sep 13 06:21:12 UTC 2005
Update of /home/or/cvsroot/tor/src/or
In directory moria:/tmp/cvs-serv21719/src/or
Modified Files:
routerlist.c
Log Message:
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.)
Index: routerlist.c
===================================================================
RCS file: /home/or/cvsroot/tor/src/or/routerlist.c,v
retrieving revision 1.282
retrieving revision 1.283
diff -u -d -r1.282 -r1.283
--- routerlist.c 12 Sep 2005 06:56:42 -0000 1.282
+++ routerlist.c 13 Sep 2005 06:21:10 -0000 1.283
@@ -117,6 +117,103 @@
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
* trusted_dir_server_t * for all known trusted dirservers. Callers
* must not modify the list or its contents.
More information about the tor-commits
mailing list