Add a build info metric to Prometheus (#6005)
This commit is contained in:
parent
ea6956c55c
commit
aeb9b2179e
|
@ -0,0 +1 @@
|
||||||
|
The new Prometheus metric `synapse_build_info` exposes the Python version, OS version, and Synapse version of the running server.
|
|
@ -29,11 +29,13 @@ from prometheus_client.core import REGISTRY, GaugeMetricFamily, HistogramMetricF
|
||||||
|
|
||||||
from twisted.internet import reactor
|
from twisted.internet import reactor
|
||||||
|
|
||||||
|
import synapse
|
||||||
from synapse.metrics._exposition import (
|
from synapse.metrics._exposition import (
|
||||||
MetricsResource,
|
MetricsResource,
|
||||||
generate_latest,
|
generate_latest,
|
||||||
start_http_server,
|
start_http_server,
|
||||||
)
|
)
|
||||||
|
from synapse.util.versionstring import get_version_string
|
||||||
|
|
||||||
logger = logging.getLogger(__name__)
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
@ -385,6 +387,16 @@ event_processing_last_ts = Gauge("synapse_event_processing_last_ts", "", ["name"
|
||||||
# finished being processed.
|
# finished being processed.
|
||||||
event_processing_lag = Gauge("synapse_event_processing_lag", "", ["name"])
|
event_processing_lag = Gauge("synapse_event_processing_lag", "", ["name"])
|
||||||
|
|
||||||
|
# Build info of the running server.
|
||||||
|
build_info = Gauge(
|
||||||
|
"synapse_build_info", "Build information", ["pythonversion", "version", "osversion"]
|
||||||
|
)
|
||||||
|
build_info.labels(
|
||||||
|
" ".join([platform.python_implementation(), platform.python_version()]),
|
||||||
|
get_version_string(synapse),
|
||||||
|
" ".join([platform.system(), platform.release()]),
|
||||||
|
).set(1)
|
||||||
|
|
||||||
last_ticked = time.time()
|
last_ticked = time.time()
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
# Copyright 2018 New Vector Ltd
|
# Copyright 2018 New Vector Ltd
|
||||||
|
# Copyright 2019 Matrix.org Foundation C.I.C.
|
||||||
#
|
#
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
# you may not use this file except in compliance with the License.
|
# you may not use this file except in compliance with the License.
|
||||||
|
@ -13,8 +14,7 @@
|
||||||
# See the License for the specific language governing permissions and
|
# See the License for the specific language governing permissions and
|
||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
|
||||||
|
from synapse.metrics import REGISTRY, InFlightGauge, generate_latest
|
||||||
from synapse.metrics import InFlightGauge
|
|
||||||
|
|
||||||
from tests import unittest
|
from tests import unittest
|
||||||
|
|
||||||
|
@ -111,3 +111,21 @@ class TestMauLimit(unittest.TestCase):
|
||||||
}
|
}
|
||||||
|
|
||||||
return results
|
return results
|
||||||
|
|
||||||
|
|
||||||
|
class BuildInfoTests(unittest.TestCase):
|
||||||
|
def test_get_build(self):
|
||||||
|
"""
|
||||||
|
The synapse_build_info metric reports the OS version, Python version,
|
||||||
|
and Synapse version.
|
||||||
|
"""
|
||||||
|
items = list(
|
||||||
|
filter(
|
||||||
|
lambda x: b"synapse_build_info{" in x,
|
||||||
|
generate_latest(REGISTRY).split(b"\n"),
|
||||||
|
)
|
||||||
|
)
|
||||||
|
self.assertEqual(len(items), 1)
|
||||||
|
self.assertTrue(b"osversion=" in items[0])
|
||||||
|
self.assertTrue(b"pythonversion=" in items[0])
|
||||||
|
self.assertTrue(b"version=" in items[0])
|
||||||
|
|
Loading…
Reference in New Issue