extended details of section traefik_info
This commit is contained in:
parent
0f834e6121
commit
28bcd00368
@ -2,6 +2,8 @@
|
||||
# pylint: disable=missing-module-docstring, unused-argument,
|
||||
# pylint: disable=missing-function-docstring, line-too-long
|
||||
|
||||
import datetime
|
||||
import time
|
||||
from pprint import pprint
|
||||
|
||||
from cmk.utils import debug
|
||||
@ -16,6 +18,7 @@ from cmk.agent_based.v2 import (
|
||||
Result,
|
||||
DiscoveryResult,
|
||||
CheckResult,
|
||||
render,
|
||||
)
|
||||
|
||||
|
||||
@ -41,6 +44,9 @@ def parse_traefik_info(string_table):
|
||||
parsed_data["codename"] = line[1]
|
||||
elif line[0] == "Traefik_StartDate":
|
||||
parsed_data["startdate"] = line[1]
|
||||
# convert timestamp into seconds since epoch
|
||||
dt = datetime.datetime.fromisoformat(line[1])
|
||||
parsed_data["startdate_seconds_since_epoch"] = int(dt.timestamp())
|
||||
elif line[0] == "Agent_Runtime":
|
||||
# convert seconds into ms
|
||||
parsed_data["agent_runtime"] = float(line[1]) * 1_000
|
||||
@ -62,8 +68,12 @@ def check_traefik_info(params, section) -> CheckResult:
|
||||
codename: str = section["codename"]
|
||||
version: str = section["version"]
|
||||
startdate: str = section["startdate"]
|
||||
startdate_seconds_since_epoch: int = section["startdate_seconds_since_epoch"]
|
||||
# calculate runtime of Traefik in seconds
|
||||
current_epoch_time: int = int(time.time())
|
||||
runtime: int = current_epoch_time - startdate_seconds_since_epoch
|
||||
agent_version: str = section["agent_version"]
|
||||
agent_runtime: float = section["agent_runtime"]
|
||||
agent_runtime: float = round(section["agent_runtime"], 1)
|
||||
state: State = get_state_upper(levels=levels, value=agent_runtime)
|
||||
|
||||
yield Metric(
|
||||
@ -72,7 +82,7 @@ def check_traefik_info(params, section) -> CheckResult:
|
||||
levels=levels,
|
||||
)
|
||||
summary: str = f"Traefik version: {version}, code name: {codename}"
|
||||
details: str = f"Traefik start date: {startdate}\nAgent version: {agent_version}\nAgent execution time: {agent_runtime}"
|
||||
details: str = f"Traefik start date: {startdate}\nRunning since: {render.timespan(runtime)}\n\nAgent version: {agent_version}\nAgent execution time: {agent_runtime}ms"
|
||||
yield Result(state=state, summary=summary, details=details)
|
||||
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user