Compare commits

..

No commits in common. "main" and "v0.4" have entirely different histories.
main ... v0.4

3 changed files with 1293 additions and 1403 deletions

View File

@ -1,47 +1,4 @@
{
"__inputs": [
{
"name": "DS_PROMETHEUS",
"label": "Prometheus",
"description": "",
"type": "datasource",
"pluginId": "prometheus",
"pluginName": "Prometheus"
}
],
"__elements": {},
"__requires": [
{
"type": "panel",
"id": "bargauge",
"name": "Bar gauge",
"version": ""
},
{
"type": "grafana",
"id": "grafana",
"name": "Grafana",
"version": "9.4.3"
},
{
"type": "datasource",
"id": "prometheus",
"name": "Prometheus",
"version": "1.0.0"
},
{
"type": "panel",
"id": "stat",
"name": "Stat",
"version": ""
},
{
"type": "panel",
"id": "timeseries",
"name": "Time series",
"version": ""
}
],
"annotations": {
"list": [
{
@ -71,14 +28,14 @@
"fiscalYearStartMonth": 0,
"gnetId": 13950,
"graphTooltip": 0,
"id": null,
"id": 9,
"links": [],
"liveNow": false,
"panels": [
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"fieldConfig": {
"defaults": {
@ -138,33 +95,29 @@
},
"textMode": "value"
},
"pluginVersion": "9.4.3",
"pluginVersion": "8.5.0",
"targets": [
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"editorMode": "code",
"exemplar": true,
"expr": "tasmota_active_power_W{job=~\"$job\"}",
"expr": "tasmota_power_W{}",
"interval": "",
"legendFormat": "power_W",
"range": true,
"refId": "A"
},
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"editorMode": "code",
"exemplar": true,
"expr": "tasmota_current_A{job=~\"$job\"}",
"expr": "tasmota_current_A{}",
"hide": false,
"interval": "",
"legendFormat": "current_A",
"range": true,
"refId": "B"
}
],
@ -175,7 +128,7 @@
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"fieldConfig": {
"defaults": {
@ -234,33 +187,29 @@
},
"textMode": "value"
},
"pluginVersion": "9.4.3",
"pluginVersion": "8.5.0",
"targets": [
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"editorMode": "code",
"exemplar": true,
"expr": "avg_over_time(tasmota_active_power_W{job=~\"$job\"}[$__range])",
"expr": "avg_over_time(tasmota_power_W{}[$__range])",
"interval": "",
"legendFormat": "power_W",
"range": true,
"refId": "A"
},
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"editorMode": "code",
"exemplar": true,
"expr": "avg_over_time(tasmota_current_A{job=~\"$job\"}[$__range])",
"expr": "avg_over_time(tasmota_current_A{}[$__range])",
"hide": false,
"interval": "",
"legendFormat": "current_A",
"range": true,
"refId": "B"
}
],
@ -271,7 +220,7 @@
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"fieldConfig": {
"defaults": {
@ -314,19 +263,17 @@
"text": {},
"textMode": "auto"
},
"pluginVersion": "9.4.3",
"pluginVersion": "8.5.0",
"targets": [
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"editorMode": "code",
"exemplar": true,
"expr": "delta(tasmota_energy_kWh_total{job=~\"$job\"}[$__range])",
"expr": "delta(tasmota_energy_kWh_total[$__range])",
"interval": "",
"legendFormat": "",
"range": true,
"refId": "A"
}
],
@ -337,7 +284,7 @@
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"fieldConfig": {
"defaults": {
@ -385,19 +332,17 @@
"text": {},
"textMode": "auto"
},
"pluginVersion": "9.4.3",
"pluginVersion": "8.5.0",
"targets": [
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"editorMode": "code",
"exemplar": true,
"expr": "delta(tasmota_energy_kWh_total{job=~\"$job\"}[$__range]) * .276",
"expr": "delta(tasmota_energy_kWh_total[$__range]) * .098",
"interval": "",
"legendFormat": "",
"range": true,
"refId": "A"
}
],
@ -408,7 +353,7 @@
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"fieldConfig": {
"defaults": {
@ -451,20 +396,18 @@
"text": {},
"textMode": "auto"
},
"pluginVersion": "9.4.3",
"pluginVersion": "8.5.0",
"targets": [
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"editorMode": "code",
"exemplar": true,
"expr": "delta(tasmota_energy_kWh_total{job=~\"$job\"}[$__range])",
"expr": "delta(tasmota_energy_kWh_total[$__range])",
"format": "time_series",
"interval": "",
"legendFormat": "",
"range": true,
"refId": "A"
}
],
@ -475,7 +418,7 @@
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"fieldConfig": {
"defaults": {
@ -534,19 +477,17 @@
"text": {},
"textMode": "value"
},
"pluginVersion": "9.4.3",
"pluginVersion": "8.5.0",
"targets": [
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"editorMode": "code",
"exemplar": true,
"expr": "delta(tasmota_energy_kWh_total{job=~\"$job\"}[$__range])*.276",
"expr": "delta(tasmota_energy_kWh_total[$__range])*.098",
"interval": "",
"legendFormat": "",
"range": true,
"refId": "A"
}
],
@ -558,7 +499,7 @@
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"fieldConfig": {
"defaults": {
@ -601,20 +542,18 @@
"text": {},
"textMode": "auto"
},
"pluginVersion": "9.4.3",
"pluginVersion": "8.5.0",
"targets": [
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"editorMode": "code",
"exemplar": true,
"expr": "delta(tasmota_energy_kWh_total{job=~\"$job\"}[$__range])",
"expr": "delta(tasmota_energy_kWh_total[$__range])",
"format": "time_series",
"interval": "",
"legendFormat": "",
"range": true,
"refId": "A"
}
],
@ -625,7 +564,7 @@
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"fieldConfig": {
"defaults": {
@ -684,19 +623,17 @@
"text": {},
"textMode": "value"
},
"pluginVersion": "9.4.3",
"pluginVersion": "8.5.0",
"targets": [
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"editorMode": "code",
"exemplar": true,
"expr": "delta(tasmota_energy_kWh_total{job=~\"$job\"}[$__range])*.276",
"expr": "delta(tasmota_energy_kWh_total[$__range])*.098",
"interval": "",
"legendFormat": "",
"range": true,
"refId": "A"
}
],
@ -708,7 +645,7 @@
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"fieldConfig": {
"defaults": {
@ -767,33 +704,29 @@
},
"textMode": "value"
},
"pluginVersion": "9.4.3",
"pluginVersion": "8.5.0",
"targets": [
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"editorMode": "code",
"exemplar": true,
"expr": "max_over_time(tasmota_active_power_W{job=~\"$job\"}[$__range])",
"expr": "max_over_time(tasmota_power_W{}[$__range])",
"interval": "",
"legendFormat": "power_W",
"range": true,
"refId": "A"
},
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"editorMode": "code",
"exemplar": true,
"expr": "max_over_time(tasmota_current_A{job=~\"$job\"}[$__range])",
"expr": "max_over_time(tasmota_current_A{}[$__range])",
"hide": false,
"interval": "",
"legendFormat": "current_A",
"range": true,
"refId": "B"
}
],
@ -804,7 +737,7 @@
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"fieldConfig": {
"defaults": {
@ -851,19 +784,17 @@
},
"textMode": "auto"
},
"pluginVersion": "9.4.3",
"pluginVersion": "8.5.0",
"targets": [
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"editorMode": "code",
"exemplar": true,
"expr": "max_over_time(tasmota_voltage_V{job=~\"$job\"}[$__range])",
"expr": "max_over_time(tasmota_voltage_V{}[$__range])",
"interval": "",
"legendFormat": "",
"range": true,
"refId": "A"
}
],
@ -874,7 +805,7 @@
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"fieldConfig": {
"defaults": {
@ -920,19 +851,17 @@
},
"textMode": "auto"
},
"pluginVersion": "9.4.3",
"pluginVersion": "8.5.0",
"targets": [
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"editorMode": "code",
"exemplar": true,
"expr": "max_over_time(tasmota_energy_today_kWh_total{job=~\"$job\"}[$__range])",
"expr": "max_over_time(tasmota_energy_today_kWh_total{}[$__range])",
"interval": "",
"legendFormat": "",
"range": true,
"refId": "A"
}
],
@ -943,7 +872,7 @@
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"description": "",
"fieldConfig": {
@ -952,8 +881,6 @@
"mode": "palette-classic"
},
"custom": {
"axisCenteredZero": false,
"axisColorMode": "text",
"axisLabel": "",
"axisPlacement": "auto",
"barAlignment": 0,
@ -1025,8 +952,7 @@
"legend": {
"calcs": [],
"displayMode": "list",
"placement": "bottom",
"showLegend": true
"placement": "bottom"
},
"tooltip": {
"mode": "single",
@ -1038,15 +964,13 @@
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"editorMode": "code",
"exemplar": true,
"expr": "tasmota_active_power_W{job=~\"$job\"}",
"expr": "tasmota_power_W{}",
"format": "time_series",
"interval": "",
"legendFormat": "{{ device }}",
"range": true,
"refId": "A"
}
],
@ -1058,7 +982,7 @@
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"fieldConfig": {
"defaults": {
@ -1109,16 +1033,15 @@
"showUnfilled": true,
"text": {}
},
"pluginVersion": "9.4.3",
"pluginVersion": "8.5.0",
"targets": [
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"editorMode": "code",
"exemplar": true,
"expr": "delta(tasmota_energy_kWh_total{job=~\"$job\"}[$__range])",
"expr": "delta(tasmota_energy_kWh_total[$__range])",
"format": "table",
"instant": false,
"interval": "",
@ -1134,7 +1057,7 @@
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"description": "",
"fieldConfig": {
@ -1143,8 +1066,6 @@
"mode": "palette-classic"
},
"custom": {
"axisCenteredZero": false,
"axisColorMode": "text",
"axisLabel": "",
"axisPlacement": "auto",
"barAlignment": 0,
@ -1217,8 +1138,7 @@
"legend": {
"calcs": [],
"displayMode": "list",
"placement": "bottom",
"showLegend": true
"placement": "bottom"
},
"tooltip": {
"mode": "single",
@ -1230,7 +1150,7 @@
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"exemplar": true,
"expr": "tasmota_energy_today_kWh_total{}",
@ -1248,7 +1168,7 @@
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"fieldConfig": {
"defaults": {
@ -1256,8 +1176,6 @@
"mode": "palette-classic"
},
"custom": {
"axisCenteredZero": false,
"axisColorMode": "text",
"axisLabel": "",
"axisPlacement": "auto",
"barAlignment": 0,
@ -1316,8 +1234,7 @@
"legend": {
"calcs": [],
"displayMode": "list",
"placement": "bottom",
"showLegend": true
"placement": "bottom"
},
"tooltip": {
"mode": "single",
@ -1329,14 +1246,12 @@
{
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
"uid": "XOGiKiT7k"
},
"editorMode": "code",
"exemplar": true,
"expr": "rate(tasmota_active_power_W{job=~\"$job\"}[1h])",
"expr": "rate(tasmota_power_W[1h])",
"interval": "",
"legendFormat": " Rate of Power",
"range": true,
"refId": "A"
}
],
@ -1345,38 +1260,12 @@
"type": "timeseries"
}
],
"refresh": "5s",
"revision": 1,
"schemaVersion": 38,
"refresh": "10s",
"schemaVersion": 36,
"style": "dark",
"tags": [],
"templating": {
"list": [
{
"current": {},
"datasource": {
"type": "prometheus",
"uid": "${DS_PROMETHEUS}"
},
"definition": "label_values(job)",
"description": "variable to filter plugs by job",
"hide": 0,
"includeAll": true,
"label": "Job",
"multi": false,
"name": "job",
"options": [],
"query": {
"query": "label_values(job)",
"refId": "StandardVariableQuery"
},
"refresh": 1,
"regex": "/^tasmota-/",
"skipUrlSync": false,
"sort": 0,
"type": "query"
}
]
"list": []
},
"time": {
"from": "now-30d",
@ -1401,6 +1290,6 @@
"timezone": "",
"title": "Tasmota Plug Usage",
"uid": "_nyxoAfMk3",
"version": 10,
"version": 33,
"weekStart": ""
}
}

View File

@ -5,15 +5,14 @@ from os import getenv
from time import sleep
from prometheus_client.core import GaugeMetricFamily, REGISTRY, CounterMetricFamily
from prometheus_client import start_http_server
from loguru import logger
class TasmotaCollector(object):
def __init__(self):
self.ip = getenv('DEVICE_IP')
logger.info("Env variable from DEVICE_NAME used is: " + self.ip)
self.device_name = getenv("DEVICE_NAME").lower()
logger.info("Env variable from DEVICE_NAME used is: " + self.device_name)
if not self.ip:
self.ip = "192.168.4.1"
self.user = getenv('USER')
self.password = getenv('PASSWORD')
@ -22,7 +21,7 @@ class TasmotaCollector(object):
response = self.fetch()
for key in response:
metric_name = "tasmota_" + key.lower().replace(" ", "_")
metric_name = self.device_name + "_" + key.lower().replace(" ", "_")
metric = response[key].split()[0]
unit = None
if len(response[key].split()) > 1:
@ -38,7 +37,7 @@ class TasmotaCollector(object):
def fetch(self):
url = 'http://' + self.ip + '/?m=1'
logger.info("Getting Metrics from: " + url)
session = requests.Session()
if self.user and self.password:
@ -71,9 +70,12 @@ signal.signal(signal.SIGINT, signal_handler)
if __name__ == '__main__':
port = getenv('EXPORTER_PORT')
logger.info("Starting HTTP server on port: " + port)
if not port:
port = 8000
start_http_server(int(port))
REGISTRY.register(TasmotaCollector())
while(True):
sleep(1)

View File

@ -1,3 +1,2 @@
prometheus_client
requests
loguru