From 54e6478d9faa38442008611af313ac6425b4a0c6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Thomas=20M=C3=BChlschlegel?= Date: Mon, 23 Feb 2015 09:46:07 +0100 Subject: [PATCH] create accurate timer for metric flush clamp timestamp to a precise interval #459 --- stats.js | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/stats.js b/stats.js index 157313e6..44a06c59 100644 --- a/stats.js +++ b/stats.js @@ -70,6 +70,8 @@ var conf; // Flush metrics to each backend. function flushMetrics() { + setTimeout(flushMetrics, getFlushTimeout(flushInterval)); + var time_stamp = Math.round(new Date().getTime() / 1000); if (old_timestamp > 0) { gauges[timestamp_lag_namespace] = (time_stamp - old_timestamp - (Number(conf.flushInterval)/1000)); @@ -139,7 +141,7 @@ function flushMetrics() { } } - // normally gauges are not reset. so if we don't delete them, continue to persist previous value + // normally gauges are not reset. so if we don't delete them, continue to persist previous value conf.deleteGauges = conf.deleteGauges || false; if (conf.deleteGauges) { for (var gauge_key in metrics.gauges) { @@ -171,6 +173,10 @@ function sanitizeKeyName(key) { } } +function getFlushTimeout(interval) { + return interval - (new Date().getTime() - startup_time * 1000) % flushInterval +} + // Global for the logger var l; @@ -417,7 +423,7 @@ config.configFile(process.argv[2], function (config) { } // Setup the flush timer - var flushInt = setInterval(flushMetrics, flushInterval); + var flushInt = setTimeout(flushMetrics, getFlushTimeout(flushInterval)); if (keyFlushInterval > 0) { var keyFlushPercent = Number((config.keyFlush && config.keyFlush.percent) || 100);