2014-02-11 00:12:10 +01:00
|
|
|
import os
|
|
|
|
import subprocess
|
|
|
|
from RRD import RRD, DS, RRA
|
|
|
|
|
2015-03-24 16:49:37 +01:00
|
|
|
|
2014-02-11 00:12:10 +01:00
|
|
|
class GlobalRRD(RRD):
|
|
|
|
ds_list = [
|
|
|
|
# Number of nodes available
|
|
|
|
DS('nodes', 'GAUGE', 120, 0, float('NaN')),
|
|
|
|
# Number of client available
|
|
|
|
DS('clients', 'GAUGE', 120, 0, float('NaN')),
|
|
|
|
]
|
|
|
|
rra_list = [
|
2015-03-24 16:49:37 +01:00
|
|
|
# 2 hours of 1 minute samples
|
|
|
|
RRA('AVERAGE', 0.5, 1, 120),
|
|
|
|
# 31 days of 1 hour samples
|
|
|
|
RRA('AVERAGE', 0.5, 60, 744),
|
|
|
|
# ~5 years of 1 day samples
|
|
|
|
RRA('AVERAGE', 0.5, 1440, 1780),
|
2014-02-11 00:12:10 +01:00
|
|
|
]
|
|
|
|
|
|
|
|
def __init__(self, directory):
|
|
|
|
super().__init__(os.path.join(directory, "nodes.rrd"))
|
2015-03-24 16:49:37 +01:00
|
|
|
self.ensure_sanity(self.ds_list, self.rra_list, step=60)
|
2014-02-11 00:12:10 +01:00
|
|
|
|
|
|
|
def update(self, nodeCount, clientCount):
|
|
|
|
super().update({'nodes': nodeCount, 'clients': clientCount})
|
|
|
|
|
|
|
|
def graph(self, filename, timeframe):
|
|
|
|
args = ["rrdtool", 'graph', filename,
|
|
|
|
'-s', '-' + timeframe,
|
|
|
|
'-w', '800',
|
|
|
|
'-h' '400',
|
|
|
|
'DEF:nodes=' + self.filename + ':nodes:AVERAGE',
|
|
|
|
'LINE1:nodes#F00:nodes\\l',
|
|
|
|
'DEF:clients=' + self.filename + ':clients:AVERAGE',
|
2015-03-24 16:49:37 +01:00
|
|
|
'LINE2:clients#00F:clients']
|
2014-02-11 00:12:10 +01:00
|
|
|
subprocess.check_output(args)
|