summaryrefslogtreecommitdiff
path: root/src/or/config.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2006-12-07 20:11:30 +0000
committerNick Mathewson <nickm@torproject.org>2006-12-07 20:11:30 +0000
commit7c79495137bcd3989428d65b184038aa71fbae70 (patch)
treea18217ed1dfeb55a8ba045772364d08837f20fbb /src/or/config.c
parentc304a10fd3ec7943734d47c2e95fcd1b75bf526d (diff)
downloadtor-7c79495137bcd3989428d65b184038aa71fbae70.tar.gz
tor-7c79495137bcd3989428d65b184038aa71fbae70.zip
r11468@Kushana: nickm | 2006-12-07 14:56:57 -0500
Revise logic used to flush state to disk. Now, we try to batch non-urgent changes so that we do not do too many writes, and we save very-non-urgent changes every once in a rare while, and we never save more than once per second. svn:r9047
Diffstat (limited to 'src/or/config.c')
-rw-r--r--src/or/config.c17
1 files changed, 10 insertions, 7 deletions
diff --git a/src/or/config.c b/src/or/config.c
index 9beb10a6c2..5da79db38e 100644
--- a/src/or/config.c
+++ b/src/or/config.c
@@ -3934,8 +3934,8 @@ or_state_load(void)
or_state_set(new_state);
new_state = NULL;
if (!contents) {
- global_state->dirty = 1;
- or_state_save();
+ global_state->next_write = 0;
+ or_state_save(time(NULL));
}
r = 0;
@@ -3950,7 +3950,7 @@ or_state_load(void)
/** Write the persistent state to disk. Return 0 for success, <0 on failure. */
int
-or_state_save(void)
+or_state_save(time_t now)
{
char *state, *contents;
char tbuf[ISO_TIME_LEN+1];
@@ -3959,11 +3959,14 @@ or_state_save(void)
tor_assert(global_state);
+ if (global_state->next_write > now)
+ return 0;
+
+ /* Call everything else that might dirty the state even more, in order
+ * to avoid redundant writes. */
entry_guards_update_state(global_state);
rep_hist_update_state(global_state);
-
- if (!global_state->dirty)
- return 0;
+ accounting_run_housekeeping(now);
global_state->LastWritten = time(NULL);
tor_free(global_state->TorVersion);
@@ -3988,7 +3991,7 @@ or_state_save(void)
tor_free(fname);
tor_free(contents);
- global_state->dirty = 0;
+ global_state->next_write = TIME_MAX;
return 0;
}