summaryrefslogtreecommitdiff
path: root/src/or/rephist.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2007-09-17 18:27:43 +0000
committerNick Mathewson <nickm@torproject.org>2007-09-17 18:27:43 +0000
commit93d4ad974318f48b4def653f94d7088bdc6b4e09 (patch)
treecd2f8c6f778e9bcc5169733014c8872ed26affbc /src/or/rephist.c
parent076b27aff8e27bbf1a6aa5fe8eb4bb43db597401 (diff)
downloadtor-93d4ad974318f48b4def653f94d7088bdc6b4e09.tar.gz
tor-93d4ad974318f48b4def653f94d7088bdc6b4e09.zip
r14447@Kushana: nickm | 2007-09-17 13:31:50 -0400
Track weighted fractional uptime in addition to weighted mtbf: we want to use mtbf for stable, but fractional uptime for guard. svn:r11456
Diffstat (limited to 'src/or/rephist.c')
-rw-r--r--src/or/rephist.c46
1 files changed, 46 insertions, 0 deletions
diff --git a/src/or/rephist.c b/src/or/rephist.c
index e7110f7de6..f065ad17d2 100644
--- a/src/or/rephist.c
+++ b/src/or/rephist.c
@@ -75,6 +75,10 @@ typedef struct or_history_t {
time_t start_of_run;
/** Sum of weights for runs in weighted_run_length. */
double total_run_weights;
+ /* === For fractional uptime tracking: */
+ time_t start_of_downtime;
+ unsigned long weighted_uptime;
+ unsigned long total_weighted_time;
/** Map from hex OR2 identity digest to a link_history_t for the link
* from this OR to OR2. */
@@ -287,6 +291,11 @@ rep_hist_note_router_reachable(const char *id, time_t when)
if (hist && !hist->start_of_run) {
hist->start_of_run = when;
}
+ if (hist && hist->start_of_downtime) {
+ long down_length = when - hist->start_of_downtime;
+ hist->total_weighted_time += down_length;
+ hist->start_of_downtime = 0;
+ }
}
/** We have just decided that this router is unreachable, meaning
@@ -303,6 +312,12 @@ rep_hist_note_router_unreachable(const char *id, time_t when)
hist->weighted_run_length += run_length;
hist->total_run_weights += 1.0;
hist->start_of_run = 0;
+
+ hist->weighted_uptime += run_length;
+ hist->total_weighted_time += run_length;
+ }
+ if (hist && !hist->start_of_downtime) {
+ hist->start_of_downtime = when;
}
}
@@ -340,6 +355,9 @@ rep_hist_downrate_old_runs(time_t now)
hist->weighted_run_length =
(unsigned long)(hist->weighted_run_length * alpha);
hist->total_run_weights *= alpha;
+
+ hist->weighted_uptime *= alpha;
+ hist->total_weighted_time *= alpha;
}
return stability_last_downrated + STABILITY_INTERVAL;
@@ -366,6 +384,23 @@ get_stability(or_history_t *hist, time_t when)
return total / total_weights;
}
+/** DOCDOC */
+static double
+get_weighted_fractional_uptime(or_history_t *hist, time_t when)
+{
+ unsigned long total = hist->total_weighted_time;
+ unsigned long up = hist->weighted_uptime;
+
+ if (hist->start_of_run) {
+ long run_length = (when - hist->start_of_run);
+ up += run_length;
+ total += run_length;
+ } else if (hist->start_of_downtime) {
+ total += (when - hist->start_of_downtime);
+ }
+ return ((double) up) / total;
+}
+
/** Return an estimated MTBF for the router whose identity digest is
* <b>id</b>. Return 0 if the router is unknown. */
double
@@ -378,6 +413,17 @@ rep_hist_get_stability(const char *id, time_t when)
return get_stability(hist, when);
}
+/** DOCDOC */
+double
+rep_hist_get_weighted_fractional_uptime(const char *id, time_t when)
+{
+ or_history_t *hist = get_or_history(id);
+ if (!hist)
+ return 0.0;
+
+ return get_weighted_fractional_uptime(hist, when);
+}
+
/** Return true if we've been measuring MTBFs for long enough to
* prounounce on Stability. */
int