summaryrefslogtreecommitdiff
path: root/src/or
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2007-08-20 16:34:17 +0000
committerNick Mathewson <nickm@torproject.org>2007-08-20 16:34:17 +0000
commit3effc8b2673aee3b1255b210947cdb41c045e257 (patch)
treedae7088feefb1d41a0c848fbcbc5cbb67cb4d566 /src/or
parenta8a7ef3da6cd16a30adc0ba250a1ade51dcde59c (diff)
downloadtor-3effc8b2673aee3b1255b210947cdb41c045e257.tar.gz
tor-3effc8b2673aee3b1255b210947cdb41c045e257.zip
r14733@catbus: nickm | 2007-08-20 12:32:44 -0400
Clean up MTBF storage code. Do not count times that we have been down toward the current run. Handle backward timewarps correctly. Store MTBF data on exit in addition to periodically. svn:r11225
Diffstat (limited to 'src/or')
-rw-r--r--src/or/config.c7
-rw-r--r--src/or/main.c14
-rw-r--r--src/or/or.h4
-rw-r--r--src/or/rephist.c51
4 files changed, 48 insertions, 28 deletions
diff --git a/src/or/config.c b/src/or/config.c
index 2dc3b973f1..200862bdc6 100644
--- a/src/or/config.c
+++ b/src/or/config.c
@@ -1006,12 +1006,7 @@ options_act(or_options_t *old_options)
return -1;
/* XXXX020 make this conditional? */
- len = strlen(options->DataDirectory)+32;
- fn = tor_malloc(len);
- tor_snprintf(fn, len, "%s"PATH_SEPARATOR"router-stability",
- options->DataDirectory);
- rep_hist_load_mtbf_data(fn, time(NULL));
- tor_free(fn);
+ rep_hist_load_mtbf_data(time(NULL));
}
/* Bail out at this point if we're not going to be a client or server:
diff --git a/src/or/main.c b/src/or/main.c
index d97c74450a..4096c40712 100644
--- a/src/or/main.c
+++ b/src/or/main.c
@@ -845,8 +845,7 @@ run_scheduled_events(time_t now)
static time_t time_to_add_entropy = 0;
static time_t time_to_write_hs_statistics = 0;
static time_t time_to_downrate_stability = 0;
- /* XXXX020 this is way too low. */
-#define SAVE_STABILITY_INTERVAL (10*60)
+#define SAVE_STABILITY_INTERVAL (30*60)
static time_t time_to_save_stability = 0;
or_options_t *options = get_options();
int i;
@@ -942,14 +941,9 @@ run_scheduled_events(time_t now)
if (!time_to_save_stability)
time_to_save_stability = now + SAVE_STABILITY_INTERVAL;
if (time_to_save_stability < now) {
- size_t len = strlen(options->DataDirectory)+32;
- char *fn = tor_malloc(len);
- tor_snprintf(fn, len, "%s"PATH_SEPARATOR"router-stability",
- options->DataDirectory);
- if (rep_hist_record_mtbf_data(fn)<0) {
- log_warn(LD_GENERAL, "Couldn't store mtbf data in %s", fn);
+ if (rep_hist_record_mtbf_data()<0) {
+ log_warn(LD_GENERAL, "Couldn't store mtbf data.");
}
- tor_free(fn);
time_to_save_stability = now + SAVE_STABILITY_INTERVAL;
}
@@ -1851,6 +1845,8 @@ tor_cleanup(void)
accounting_record_bandwidth_usage(time(NULL), get_or_state());
or_state_mark_dirty(get_or_state(), 0); /* force an immediate save. */
or_state_save(time(NULL));
+ if (authdir_mode_tests_reachability(options))
+ rep_hist_record_mtbf_data();
}
#ifdef USE_DMALLOC
dmalloc_log_stats();
diff --git a/src/or/or.h b/src/or/or.h
index 87f00ac02d..809d69695c 100644
--- a/src/or/or.h
+++ b/src/or/or.h
@@ -3119,8 +3119,8 @@ void rep_history_clean(time_t before);
void rep_hist_note_router_reachable(const char *id, time_t when);
void rep_hist_note_router_unreachable(const char *id, time_t when);
-int rep_hist_record_mtbf_data(const char *filename);
-int rep_hist_load_mtbf_data(const char *filename, time_t now);
+int rep_hist_record_mtbf_data(void);
+int rep_hist_load_mtbf_data(time_t now);
time_t rep_hist_downrate_old_runs(time_t now);
double rep_hist_get_stability(const char *id, time_t when);
diff --git a/src/or/rephist.c b/src/or/rephist.c
index a74a28315e..0474ee644a 100644
--- a/src/or/rephist.c
+++ b/src/or/rephist.c
@@ -503,8 +503,19 @@ rep_history_clean(time_t before)
}
/** DOCDOC */
+static char *
+get_mtbf_filename(void)
+{
+ const char *datadir = get_options()->DataDirectory;
+ size_t len = strlen(datadir)+32;
+ char *fn = tor_malloc(len);
+ tor_snprintf(fn, len, "%s"PATH_SEPARATOR"router-stability", datadir);
+ return fn;
+}
+
+/** DOCDOC */
int
-rep_hist_record_mtbf_data(const char *filename)
+rep_hist_record_mtbf_data(void)
{
char buf[128];
char time_buf[ISO_TIME_LEN+1];
@@ -529,7 +540,6 @@ rep_hist_record_mtbf_data(const char *filename)
smartlist_add(lines, tor_strdup(buf));
}
-
smartlist_add(lines, tor_strdup("data\n"));
for (orhist_it = digestmap_iter_init(history_map);
@@ -557,10 +567,12 @@ rep_hist_record_mtbf_data(const char *filename)
size_t sz;
/* XXXX This isn't terribly efficient; line-at-a-time would be
* way faster. */
+ char *filename = get_mtbf_filename();
char *data = smartlist_join_strings(lines, "", 0, &sz);
int r = write_bytes_to_file(filename, data, sz, 0);
tor_free(data);
+ tor_free(filename);
SMARTLIST_FOREACH(lines, char *, cp, tor_free(cp));
smartlist_free(lines);
return r;
@@ -569,16 +581,18 @@ rep_hist_record_mtbf_data(const char *filename)
/** DOCDOC */
int
-rep_hist_load_mtbf_data(const char *filename, time_t now)
+rep_hist_load_mtbf_data(time_t now)
{
/* XXXX won't handle being called while history is already populated. */
smartlist_t *lines;
const char *line = NULL;
int r=0, i;
- time_t last_downrated = 0;
+ time_t last_downrated = 0, stored_at = 0;
{
+ char *filename = get_mtbf_filename();
char *d = read_file_to_str(filename, RFTS_IGNORE_MISSING, NULL);
+ tor_free(filename);
if (!d)
return -1;
lines = smartlist_create();
@@ -599,9 +613,20 @@ rep_hist_load_mtbf_data(const char *filename, time_t now)
log_warn(LD_GENERAL,"Couldn't parse downrate time in mtbf "
"history file.");
}
- if (last_downrated > now)
- last_downrated = now;
+ if (!strcmpstart(line, "stored-at ")) {
+ if (parse_iso_time(line+strlen("stored-at "), &stored_at)<0)
+ log_warn(LD_GENERAL,"Couldn't parse stored time in mtbf "
+ "history file.");
+ }
}
+ if (last_downrated > now)
+ last_downrated = now;
+
+ if (!stored_at) {
+ log_warn(LD_GENERAL, "No stored time recorded.");
+ goto err;
+ }
+
if (line && !strcmp(line, "data"))
++i;
@@ -636,15 +661,19 @@ rep_hist_load_mtbf_data(const char *filename, time_t now)
hist = get_or_history(digest);
if (!hist)
continue;
- if (start_of_run > now)
- start_of_run = now;
- hist->start_of_run = start_of_run;
+
+ if (!start_of_run || start_of_run > stored_at) {
+ hist->start_of_run = 0;
+ } else {
+ long run_length = stored_at - start_of_run;
+ hist->start_of_run = now - run_length;
+ }
+
hist->weighted_run_length = wrl;
hist->total_run_weights = trw;
- /* Subtract time in which */
}
if (strcmp(line, "."))
- log_warn(LD_GENERAL, "Truncated MTBF file %s", escaped(filename));
+ log_warn(LD_GENERAL, "Truncated MTBF file.");
stability_last_downrated = last_downrated;