NEWS
Verschwinden von MQTT Geräten erkennen und melden
-
@martinp Frag das GErät doch nach "connected" oder "is online" ab und verarbeite das in IOB mittels eines Timers: Wenn der Client nicht mehr online ist muss die Zeit ablaufen und dann sendest Du Dir eine Nachricht
-
@guergen Falls es die Möglichkeit der Abfrage von "connected" bzw. "is online" gibt, wäre das die naheliegenste Lösung ...
Das hier habe ich schon mal mit den Stichworten von Dir gefunden:
https://stackoverflow.com/questions/36093078/mqtt-is-there-a-way-to-check-if-the-client-is-still-connected -
@martinp
Ich verstehe nicht, warum du den Umweg über MQTT gehen willst. Wenn, wie du schreibst, das Gerät aus dem WLAN fliegt, wird es wohl auch nicht mehr per Ping erreichbar sein. Und dafür gibt es ja Adapter, die das erkennen und melden.Edit: Ansonsten gibt es für deinen Anwendungsfall das MQTT Feature "LWT" (Last will and testament). Das muss aber vom Broker und Client unterstützt werden. Dann wird beim unerwarteten Disconnect vom Broker eine Nachricht gesendet.
-
Ich checke meine Datenpunkte auf Veränderung... Wenn die Temperatur meines Boilers sich nicht alle 45 Minuten aktualisiert, gibts ne Telegramnachricht. Wichtiger Sensor, der Ausfall der anderen ist zwar nervig, aber da muß ich wenigstens nicht kalt duschen.
hm-rpc mit dem aktuellen Sentrybug bleibt "connected" obwohl keine Daten mehr reinkommen.
-
@ticaki Danke für den Tipp.
Habe den ersten Schritt getan. Es scheint leider so zu sein, dass man direkt am MQTT-Datenpunkt-Baum des Geräts keinen User-Datenpunkt erzeugen kann ( "+" ist ausgegraut)
Habe den Punkt "ArbeitszimmerThermostatAlive" nun unter Userdata erzeugt ...
Die Raumtemperatur wird, wenn alles funktioniert, alle 10 Sekunden in den entsprechenden MQTT-Datenpunkt geschrieben. Das untenstehende Blockly setzt "ArbeitszimmerThermostatAlive" auf false, wenn 30 Sekunden keine Aktualisierung erfolgt...
Der Userdata Datenpunkt "ArbeitszimmerThermostatAlive" soll dann wiederum weitere Aktionen auslösen.
Wechsel auf "false" -> Alarmierung (Telegram oder Mail)
Wechsel auf "true" -> Je nach aktueller Uhrzeit Setzen der Solltemperatur auf Solltemperatur-Tag bzw -Nacht....Anmerkung: Ich muss wahrscheinlich dringend an der Benennung von Elementen arbeiten. Die Benennungen sind ggfs. so generisch, dass es schwierig werden könnte nach dem Muster meines Arbeitszimmer-Thermostats noch weitere Thermostaten zu bauen und in ioBroker zu integrieren ...
-
@martinp sagte in Verschwinden von MQTT Geräten erkennen und melden:
Habe den ersten Schritt getan. Es scheint leider so zu sein, dass man direkt am MQTT-Datenpunkt-Baum des Geräts keinen User-Datenpunkt erzeugen kann ( "+" ist ausgegraut)
Kann man schon, dann gehst Du so lange noch oben bis das + wieder auftaucht und gibst den Pfad von da mit einem Punkt an. Das ist leider so ein Mist vom Admin 5 - dass der immer meint bestimmen zu können, wo etwas erstellt werden darf und man mqtt von diesen Regeln nicht ausnimmt.
-
@mickym Habe da gerade mal ein wenig herumgeklickt: Alle Knoten inclusive dem MQTT-Knoten selber haben ein ausgegrautes "+".
Nur unter "0_userdata.0" und "alias.0" kann ich etwas anlegen...
"alias" klingt ja ggfs. recht vielversprechend - vielleicht mal etwas einlesen in die Philosopie dahinter ...
-
@martinp Du musst den Expertenmodus anmachen.
-
@mickym Okay, der schwarze Indianer ist der Expertenmodus, wieder was gelernt
Dann kann ich sogar direkt im Thermostat-Knoten neue Datenpunkte erzeugen...
-
Noch eine Frage, die mit dem Thema zu tun hat: Gibt es in Blockly so eine Art "Templates"?
Wenn ich das Blockly-Skript, was den "IsAlive" Zustand in den MQTT-Pfad eines Gerätes in einen angelegten Knoten unterhalb dieses Pfades schreiben will nicht durch COPY&Paste erzeugen möchte ...
Es gäbe z. B.
system.adapter.mqtt.0.thermostat
system.adapter.mqtt.0.thermostat_2
system.adapter.mqtt.0.thermostat_3
system.adapter.mqtt.0.thermostat_4wenn jeweils die raumtemperatur für die timeout-zeit nicht aktualisiert wird, soll der darunterliegende IsAlive Knoten auf false gesetzt werden.
Man kann natürlich zuerst das Skript für ...thermostat basteln, und dann durch copy&paste des ganzes skripts kopien erstellen in denen man jeweils thermostat durch thermostat_2 etc. ersetzt, aber das heißt, man hat bei jeder Änderung vier Stellen, an denen man anfassen muss, und das ist mühselig und fehleranfällig ...
Wahrscheinlich ist aber Blockly dazu nicht vorgesehen, und man wird auf Lösungen per Javascript gehen müssen ...
-
@martinp sagte in Verschwinden von MQTT Geräten erkennen und melden:
Dann kann ich sogar direkt im Thermostat-Knoten neue Datenpunkte erzeugen...
Keine gute Idee. Diese Daten sind "vergänglich". Für eigene Datenpunkte inklusive Verzeichnisse bitte "0_userdata.0." verwenden.
Ro75.
-
@martinp sagte in Verschwinden von MQTT Geräten erkennen und melden:
Wenn ich das Blockly-Skript, was den "IsAlive" Zustand in den MQTT-Pfad eines Gerätes in einen angelegten Knoten unterhalb dieses Pfades schreiben will nicht durch COPY&Paste erzeugen möchte ...
Du kannst statt die Datenpunkte manuell anzulegen auch über das SendTo Puzzleteil an den Mqtt-Adapter die Werte publishen. Alle veröffentlichen topics werden dann automatisch als Datenpunkte angelegt.
Statt fixer Werte kannst du natürlich auch Variablen verwenden etc.
-
@ro75 sagte in Verschwinden von MQTT Geräten erkennen und melden:
@martinp sagte in Verschwinden von MQTT Geräten erkennen und melden:
Dann kann ich sogar direkt im Thermostat-Knoten neue Datenpunkte erzeugen...
Keine gute Idee. Diese Daten sind "vergänglich". Für eigene Datenpunkte inklusive Verzeichnisse bitte "0_userdata.0." verwenden.
Ro75.
Na ja - im MQTT generell gebe ich Dir Recht, dass sobald alle Subscriber informiert werden sollten, die Daten wieder aufgeräumt werden sollten. Im MQTT-Adapter jedoch nicht - was sogar eigentlich ein Problem darstellt. Deswegen kommt der Adapter auch mit dem retained Flag nicht so klar und alle Daten bleiben eigentlich bis ULTIMO vorhanden, bis sie manuell gelöscht werden. Ansonsten ist ein aber ein MQTT-Broker bei Veröffentlichen von Daten mit retained Flag durchaus ein valider Datenspeicher - das ist aber eher allgemein zu sehen und ist nicht iobroker spezifisch.
-
@mickym said in Verschwinden von MQTT Geräten erkennen und melden:
@martinp sagte in Verschwinden von MQTT Geräten erkennen und melden:
Wenn ich das Blockly-Skript, was den "IsAlive" Zustand in den MQTT-Pfad eines Gerätes in einen angelegten Knoten unterhalb dieses Pfades schreiben will nicht durch COPY&Paste erzeugen möchte ...
Du kannst statt die Datenpunkte manuell anzulegen auch über das SendTo Puzzleteil an den Mqtt-Adapter die Werte publishen. Alle veröffentlichen topics werden dann automatisch als Datenpunkte angelegt.
Statt fixer Werte kannst du natürlich auch Variablen verwenden etc.
Ich meinte das etwas anders - wenn jetzt ein Thermostat dazu kommt, muss man das Blockly Skript aus Deinem Beispiel kopieren, und in der Kopie z. B. "Thermostat1" durch "Thermostat2" ersetzen...
Wenn man dann 6 Thermostate hat, und etwas in der Logik des Blockly Skriptes ändert, muss man immer daran denken, auch die entsprechenden Änderungen in den 5 Kopien nachzuziehen.... -
@martinp Nein das sagte ich doch, Du kannst Doch das ganze in eine Schleife einbinden und über ein Array durchiterieren.Oder Du triggerst direkt über den Thermostat oder abfragst. Wie gesagt welche Logik zum Abfragen du nimmst oder triggern ist Deine Sache.
Aber so kannst Du einfach eine Liste von Thermostaten erstellen und alle topics erstellem_
das sind aber Basics beim Puzzeln (Geht aber auch mit steuere oder aktualisiere von Datenpunkten). Wie gesagt das sind Basics, dass man identische Codeteile über Schleifen durchläuft. Und wer mich kennt, weiss, dass ich ein anderes Tool bevorzuge - das sogar direkt mit mqtt kommunizieren kann.