diff options
author | Nick Mathewson <nickm@torproject.org> | 2006-12-07 20:11:30 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2006-12-07 20:11:30 +0000 |
commit | 7c79495137bcd3989428d65b184038aa71fbae70 (patch) | |
tree | a18217ed1dfeb55a8ba045772364d08837f20fbb /src/or/config.c | |
parent | c304a10fd3ec7943734d47c2e95fcd1b75bf526d (diff) | |
download | tor-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.c | 17 |
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; } |