NEWS
MQTT Keepalive im Skript
-
@dan11hh wie gesagt musst du nicht, wenn du dieses phantastische Tool nicht nutzen willst.
Falls doch, hat’s du sowohl die mqtt Nodes direkt an Board und ich hab einen Subflow gemacht, der - wenn du NodeRed mit dem iobroker nutzt - Dir die Datenpunkte direkt schreibt.
https://forum.iobroker.net/topic/43856/json-oder-javascript-objekt-in-iobroker-datenpunkte-zerlegen
Siehe Beispiel 6. Inzwischen geht es auch mit Variablen Topics, so dass auch ganze Bäume kein Problem mehr sein sollten..
Nachdem aber alles mit dem mqtt-Adapter soweit bereits funktioniert, kannst Du natürlich auch direkt aus dem iobroker die Daten mit NodeRed auslesen und schreiben lassen. Dann solltest du aber mal einen Screenshot von den Datenpunkten machen, die Du Dich interessieren, dann können wir den Flow zusammen entwickeln.
-
@mickym Hallo, ich stehe vor diesem Thema und möchte mich gerne hier einklinken, auch wenn es schon vor guter Zeit gelöst wurde.
Ich bin Java nicht mächtig, dh ich kann Blockly und in Zukunft auch Node-Red.
Wäre es ev. sinnvoll Node-Red für den Alive zu verwenden, der Victron arbeitet auch mit Node-Red, ev. eine gute Schnittstelle. Der Mqtt vom Victron ist im ioBroker als Slave drin, die ersten Strukturen werden angelget, auch wenn nicht vollständig?mit welchem Node mache ich diesen Alive, sry, steh da echt noch beim Start und muss noch viel lernen. Danke!
Summary (the important bits) To activate keep-alive, send a read request to R/<portal ID>/keepalive. The payload may be blank, or may contain a list of topics of interest. See the next section for details on this.
ein reiner "read" request ohne payload, ?
-
@humidor Mit einer Inject Node kannst Du Nachrichten erzeugen - entweder manuell über den Taster oder dann mit Wiederholung. Mit einer mqtt-Out sendest Du dann diese payload an das keepalive topic.
-
@mickym mache ich schon, leider kommt nichts daher vom Cerbo....
Zugriffsrechte?
-
@humidor Na wenn Du eine leere payload schickst, kommt ja auch nichts (übrigens immer mit / die topics voneinander trennen) - es dient ja lediglich dazu zu zeigen, dass die Verbindung noch aktiv ist. Wenn also (null) drinsteht, dann ist das eine leere payload. Alternativ steht ja kann man dem Teil eine Liste auf topics schicken. Ich kann somit keine Fehler erst mal entdecken.
Wenn Du willst dass dauernd alles veröffentlicht wird, dann solltest Du wohl besser die Methode a verwenden:
-
@mickym es funktioniert jetzt mit serial beschreiben, der Objektbaum is riesig.
-
@humidor Ja steht ja in der Beschreibung - dass dann immer alles gepublished wird. Wenn man nur einzelne topics haben will, dass muss man das wie beschrieben halt in das keepalive topic schreiben.
-
@mickym schon klar, wie ich einzelne abrufe weiß ich noch nicht, muss noch rausfinden
-
@humidor sagte in MQTT Keepalive im Skript:
@mickym schon klar, wie ich einzelne abrufe weiß ich noch nicht, muss noch rausfinden
Na das steht doch weiter unten:
In das keepalive kannst ein Array mitgeben, mit einzelnen topics oder sogar mit Wildcards welche Äste.
-
@mickym das ist sehr schön, dass es da steht, wie setzt man es um, ich bin kein programmierer.... und das wird ja nicht gesagt, das muss man wieder rausfinden
-
@mickym Um das in dem Beispiel benutzte Array zu verwenden gibst du das ArrAY
@humidor sagte in MQTT Keepalive im Skript:
@mickym das ist sehr schön, dass es da steht, wie setzt man es um, ich bin kein programmierer.... und das wird ja nicht gesagt, das muss man wieder rausfinden
Na um das unten gesagte Array zu senden modifizierst Du nur deine Inject NOde.
Hier die Inject Node zum Import:
und sendest das dann an den keepalive topic.
So kannst Du einzelne topics häufiger abfragen und andere weniger häufig.
-
@mickym ist das so ev. richtig? oder muss der payload anders injected werden?
-
@humidor Ja das passt schon - Du musst halt in das array nur reinschreiben, was Du haben möchtest. Und eigenltich hätte auch alles kommen müssen wenn Du eine leere payload schickst. Weiß aber nicht warum, warum das nicht gegangen ist. Jedenfalls funktioniert ja Deine Kommunikation grundsätzlich, sonst wäre es ja über die Serial 0 nicht gegangen. Ob es den Ast vebus etc gibt oder Du die verschiedenen solarcharger topics gibt weiss ich nicht.
Mit # nimmst du immer alles was darunter ist - das Pluszeichen ist hingegegen ein Wildcard auf der jeweiligen Hierarchieebene.
-
@mickym also das laden eines Wertes fkt. noch nicht
kommt nix
-
@humidor Na das ist doppelt gemoppelt.
Mit system/# nimmst Du ja alle was drunter ist, d.h. das oben drüber ist redundant. Keep Alive heißt ja auch nur dass Änderungen gepublished werden. Also wenn das Teil nichts ändert kommt auch nichts an. KeepAlive heißt nicht, dass es alles sofort published.
Wenn Du AKTIV was auslesen willst, dann musst Du direkt das topic ansprechen.
Wenn Du direkt den Power Datenpunkt auslesen willst
dann musst Du eine leere payload an das Power topic schicken.
So und nun Achtung: Die Antwort kommt im N Ast an - im R Ast sendest Du den Request.
-
@mickym öhmm, steh auf der Leitung
keepalive nur als trigger
der Datenpunkt direkt auslesen, sowie keepalive? dachte das wird nur als payload angehängt?
was ist das dann mit mehreren Werten?
einen R Ast habe ich nicht im Objektbaum -
@humidor Na keepalive verstehe ich so, dass diese topics gepu
@humidor sagte in MQTT Keepalive im Skript:
einen R Ast habe ich nicht im Objektbaum
Brauchst Du auch nicht. Ein Gerät wird nie auf ein topic was es hört selbst was veröffentlichen. Gibt das einfach in mit dem R in die mqtt Out NOde ein. Was Du im iobroker siehst ist nur ein Spiegel. Wenn da noch nichts veröffentlich wurde unter dem topic siehst du nichts. Du müsstest den Datenpunkt mit Send oder manuell anlegen. In Node Red kannst Du einfach das R topic in die mqtt out NOde schreiben.
-
@mickym den power habe ich schon so ausgesucht, da kommen Werte rein (serial)
damit das jetzt verstehe, die Mqtt Out mit keepalive lasse ich ohne payload, nur der Trigger drauf ?
ein weiteres Mqtt out mit payload auf den Wert
-
@humidor Nochmal sende einfach an den R Ast den kompletten Pfad eine leere payload.
-
@mickym ich verstehe das nicht was du sagst, es klingt logisch, ich hab aber null ahnung wie ich das in den nodes umsetze
ist das mal der richtige Ansatz?