summaryrefslogtreecommitdiff
path: root/src/or
diff options
context:
space:
mode:
authorPeter Retzlaff <peter.retzlaff@student.hpi.uni-potsdam.de>2013-06-12 10:51:39 +0200
committerNick Mathewson <nickm@torproject.org>2013-08-21 13:26:57 -0400
commita337d4b7cb9ae7f4e4ec4567b9efd64bbed70298 (patch)
tree43fb710e70706a1de7b02258b1e1170162dee355 /src/or
parent28485d33ca64ee3989f6993a1c30f265be9e324f (diff)
downloadtor-a337d4b7cb9ae7f4e4ec4567b9efd64bbed70298.tar.gz
tor-a337d4b7cb9ae7f4e4ec4567b9efd64bbed70298.zip
Print accounting information in heartbeat messages.
Implements ticket 5526.
Diffstat (limited to 'src/or')
-rw-r--r--src/or/hibernate.c6
-rw-r--r--src/or/hibernate.h1
-rw-r--r--src/or/status.c28
-rw-r--r--src/or/status.h1
4 files changed, 36 insertions, 0 deletions
diff --git a/src/or/hibernate.c b/src/or/hibernate.c
index 22c0f253da..712a6959a6 100644
--- a/src/or/hibernate.c
+++ b/src/or/hibernate.c
@@ -255,6 +255,12 @@ accounting_get_interval_length(void)
return (int)(interval_end_time - interval_start_time);
}
+time_t
+accounting_get_end_time(void)
+{
+ return interval_end_time;
+}
+
/** Called from main.c to tell us that <b>seconds</b> seconds have
* passed, <b>n_read</b> bytes have been read, and <b>n_written</b>
* bytes have been written. */
diff --git a/src/or/hibernate.h b/src/or/hibernate.h
index 18832fbc6c..4f7331ce8c 100644
--- a/src/or/hibernate.h
+++ b/src/or/hibernate.h
@@ -15,6 +15,7 @@
int accounting_parse_options(const or_options_t *options, int validate_only);
int accounting_is_enabled(const or_options_t *options);
int accounting_get_interval_length(void);
+time_t accounting_get_end_time(void);
void configure_accounting(time_t now);
void accounting_run_housekeeping(time_t now);
void accounting_add_bytes(size_t n_read, size_t n_written, int seconds);
diff --git a/src/or/status.c b/src/or/status.c
index 577587d452..2fda471947 100644
--- a/src/or/status.c
+++ b/src/or/status.c
@@ -15,6 +15,7 @@
#include "circuitlist.h"
#include "main.h"
#include "hibernate.h"
+#include "statefile.h"
/** Return the total number of circuits. */
static int
@@ -111,6 +112,10 @@ log_heartbeat(time_t now)
uptime, count_circuits(),bw_sent,bw_rcvd,
hibernating?" We are currently hibernating.":"");
+ if (server_mode(options) && accounting_is_enabled(options) && !hibernating) {
+ log_accounting(now, options);
+ }
+
if (stats_n_data_cells_packaged && !hibernating)
log_notice(LD_HEARTBEAT, "Average packaged cell fullness: %2.3f%%",
100*(U64_TO_DBL(stats_n_data_bytes_packaged) /
@@ -128,3 +133,26 @@ log_heartbeat(time_t now)
return 0;
}
+void
+log_accounting(const time_t now, const or_options_t *options)
+{
+ or_state_t *state = get_or_state();
+ char *acc_rcvd = bytes_to_usage(state->AccountingBytesReadInInterval);
+ char *acc_sent = bytes_to_usage(state->AccountingBytesWrittenInInterval);
+ char *acc_max = bytes_to_usage(options->AccountingMax);
+ time_t interval_end = accounting_get_end_time();
+ char end_buf[ISO_TIME_LEN + 1];
+ char *remaining = NULL;
+ format_local_iso_time(end_buf, interval_end);
+ remaining = secs_to_uptime(interval_end - now);
+
+ log_notice(LD_HEARTBEAT, "Heartbeat: "
+ "Sent: %s / %s, Received: %s / %s. The "
+ "current accounting period ends on %s. That's %s left to go.",
+ acc_sent, acc_max, acc_rcvd, acc_max, end_buf, remaining);
+
+ tor_free(acc_rcvd);
+ tor_free(acc_sent);
+ tor_free(acc_max);
+ tor_free(remaining);
+}
diff --git a/src/or/status.h b/src/or/status.h
index 7c3b969c86..4a334b156d 100644
--- a/src/or/status.h
+++ b/src/or/status.h
@@ -5,6 +5,7 @@
#define TOR_STATUS_H
int log_heartbeat(time_t now);
+void log_accounting(const time_t now, const or_options_t *options);
#endif