self.timeout = timeout
self.heartbeat = heartbeat
+ self.delay = 0
+
self.reset()
- def reset(self):
+ def reset(self, delay=0):
# Save start time.
self.start = time.time()
+ self.delay = delay
+
# Has this timer been killed?
self.killed = False
@property
def elapsed(self):
- return time.time() - self.start
+ return time.time() - self.start - self.delay
def cancel(self):
self.killed = True
def stepsize(self):
return self.interval
+ @property
+ def heartbeat(self):
+ return self.stepsize * 2
+
@property
def file(self):
"""
rrdtool.create(self.file, *args)
self.log.debug(_("Created RRD file %s.") % self.file)
+ for arg in args:
+ self.log.debug(" %s" % arg)
def get_rrd_schema(self):
schema = [
prefix,
name,
type,
- "%s" % self.stepsize,
+ "%s" % self.heartbeat,
lower_limit,
upper_limit
))
return
self.log.debug(_("Submitting data to database. %d entries.") % len(self.data))
+ for data in self.data:
+ self.log.debug(" %s" % data)
+
+ # Create the RRD files (if they don't exist yet or
+ # have vanished for some reason).
+ self.create()
+
rrdtool.update(self.file, *self.data)
self.data = []