diff options
author | Erik Johnston <erik@matrix.org> | 2018-04-11 11:07:33 +0100 |
---|---|---|
committer | Erik Johnston <erik@matrix.org> | 2018-04-11 12:13:40 +0100 |
commit | ab825aa328e089b28cf858332bb95f47e1490377 (patch) | |
tree | 0ad6c76a9d6c7cd6541217d1e27b6d23b96c7781 /synapse/metrics/metric.py | |
parent | Merge pull request #2760 from Valodim/pypy (diff) | |
download | synapse-ab825aa328e089b28cf858332bb95f47e1490377.tar.xz |
Add GaugeMetric
Diffstat (limited to '')
-rw-r--r-- | synapse/metrics/metric.py | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/synapse/metrics/metric.py b/synapse/metrics/metric.py index ff5aa8c0e1..9ebf2d6fdb 100644 --- a/synapse/metrics/metric.py +++ b/synapse/metrics/metric.py @@ -145,6 +145,36 @@ class CounterMetric(BaseMetric): ) +class GaugeMetric(BaseMetric): + """A metric that can go up or down + """ + + def __init__(self, *args, **kwargs): + super(GaugeMetric, self).__init__(*args, **kwargs) + + # dict[list[str]]: value for each set of label values. the keys are the + # label values, in the same order as the labels in self.labels. + # + # (if the metric is a scalar, the (single) key is the empty list). + self.guages = {} + + def set(self, v, *values): + if len(values) != self.dimension(): + raise ValueError( + "Expected as many values to inc() as labels (%d)" % (self.dimension()) + ) + + # TODO: should assert that the tag values are all strings + + self.guages[values] = v + + def render(self): + return flatten( + self._render_for_labels(k, self.guages[k]) + for k in sorted(self.guages.keys()) + ) + + class CallbackMetric(BaseMetric): """A metric that returns the numeric value returned by a callback whenever it is rendered. Typically this is used to implement gauges that yield the |