aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2007-05-22 01:51:53 +0000
committerNick Mathewson <nickm@torproject.org>2007-05-22 01:51:53 +0000
commit32c8d94c12fdbb38776b52d3b6d593c85d8cfd58 (patch)
treebf868f6cf8c743bb7e201d64dfe39a9c2171463f
parent590a98ff372fcc9f1aeb24b163506997e60fc9ce (diff)
downloadtor-32c8d94c12fdbb38776b52d3b6d593c85d8cfd58.tar.gz
tor-32c8d94c12fdbb38776b52d3b6d593c85d8cfd58.zip
r12842@catbus: nickm | 2007-05-21 21:51:45 -0400
Partial backport candidate. Fix issue noted in r10241: stores were rebuilt too often. Also notes dropped bytes better. svn:r10244
-rw-r--r--ChangeLog2
-rw-r--r--src/or/routerlist.c11
2 files changed, 10 insertions, 3 deletions
diff --git a/ChangeLog b/ChangeLog
index 543337176c..3cf0c08639 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -159,6 +159,8 @@ Changes in version 0.2.0.1-alpha - 2007-??-??
- When choosing an entry guard for our circuit, avoid using guards
that are in the same family as the chosen exit -- not just guards
that are exactly the chosen exit. (Reported by lodger.)
+ - Don't rebuild the entire router store just because we got 32K of
+ routers.
o Minor bugfixes (controller):
- Make 'getinfo fingerprint' return a 551 error if we're not a
diff --git a/src/or/routerlist.c b/src/or/routerlist.c
index 2f33ca8678..d03e330962 100644
--- a/src/or/routerlist.c
+++ b/src/or/routerlist.c
@@ -271,7 +271,6 @@ _compare_signed_descriptors_by_age(const void **_a, const void **_b)
static int
router_rebuild_store(int force, int extrainfo)
{
- size_t len = 0; /* XXX020 never used */
or_options_t *options;
size_t fname_len;
smartlist_t *chunk_list = NULL;
@@ -394,7 +393,8 @@ router_rebuild_store(int force, int extrainfo)
write_str_to_file(fname, "", 1);
r = 0;
- stats->store_len = len; /* XXX020 always 0 */
+ tor_assert(offset > 0);
+ stats->store_len = (size_t) offset;
stats->journal_len = 0;
stats->bytes_dropped = 0;
done:
@@ -1827,8 +1827,11 @@ extrainfo_insert(routerlist_t *rl, extrainfo_t *ei)
ei->cache_info.signed_descriptor_digest,
ei);
r = 1;
- if (ei_tmp)
+ if (ei_tmp) {
+ extrainfo_store_stats.bytes_dropped +=
+ ei_tmp->cache_info.signed_descriptor_len;
extrainfo_free(ei_tmp);
+ }
done:
if (r == 0)
@@ -2035,6 +2038,8 @@ routerlist_replace(routerlist_t *rl, routerinfo_t *ri_old,
if (!tor_digest_is_zero(ri_old->cache_info.extra_info_digest))
digestmap_remove(rl->desc_by_eid_map,
ri_old->cache_info.extra_info_digest);
+ router_store_stats.bytes_ropped +=
+ ri_old->cache_info.signed_descriptor_len;
routerinfo_free(ri_old);
}
#ifdef DEBUG_ROUTERLIST