summaryrefslogtreecommitdiff
path: root/kvmd
diff options
context:
space:
mode:
authorMaxim Devaev <[email protected]>2023-07-24 16:25:25 +0300
committerMaxim Devaev <[email protected]>2023-07-24 16:25:25 +0300
commit2b0515dc55f2be7b0d88afa9257f852c823a9b40 (patch)
treeec1280ccde0dc53567c90dc8df557feb6878c05d /kvmd
parent78ceb345acff0277c0dba5b3e4e99044c17d903c (diff)
cached /export/prometheus/metrics
Diffstat (limited to 'kvmd')
-rw-r--r--kvmd/apps/kvmd/api/export.py8
1 files changed, 7 insertions, 1 deletions
diff --git a/kvmd/apps/kvmd/api/export.py b/kvmd/apps/kvmd/api/export.py
index cfcbde41..a5d4d0bf 100644
--- a/kvmd/apps/kvmd/api/export.py
+++ b/kvmd/apps/kvmd/api/export.py
@@ -24,6 +24,8 @@ import asyncio
from typing import Any
+import async_lru
+
from aiohttp.web import Request
from aiohttp.web import Response
@@ -49,6 +51,10 @@ class ExportApi:
@exposed_http("GET", "/export/prometheus/metrics")
async def __prometheus_metrics_handler(self, _: Request) -> Response:
+ return Response(text=(await self.__get_prometheus_metrics()))
+
+ @async_lru.alru_cache(maxsize=1, ttl=5)
+ async def __get_prometheus_metrics(self) -> str:
(atx_state, hw_state, fan_state, gpio_state) = await asyncio.gather(*[
self.__atx.get_state(),
self.__info_manager.get_submanager("hw").get_state(),
@@ -68,7 +74,7 @@ class ExportApi:
self.__append_prometheus_rows(rows, hw_state["health"], "pikvm_hw")
self.__append_prometheus_rows(rows, fan_state, "pikvm_fan")
- return Response(text="\n".join(rows))
+ return "\n".join(rows)
def __append_prometheus_rows(self, rows: list[str], value: Any, path: str) -> None:
if isinstance(value, bool):