NEWS
Mqtt best practice
-
@dos1973 sagte in Mqqt best practice:
@mickym sagte in Mqqt best practice:
So nun hab ich aber glaube genug Möglichkeiten der Steuerung ohne Adapter aufgezeigt
eindeutiges JA.
eigentlich war/ ist genau das mein Ziel.
Da ich inzwischen Zuviele von den kleinen Dingern habe, möchte ich nicht Abhängig vom Adapter und der Entwicklung sein.kann der node-red "Status Teil exportiert werden. Das sehen ja bestimmt noch Sachen drin welche im Screenshot nicht ersichtlich sind.
Der Subflow-Node ist hier in meinem Thread genau beschrieben (z. Bsp muss man im NodeRed Adapter die Erstellung von Fremdobjekten zulassen und die Stringkonvertierung ausschalten):
Beides hier nochmal als Screenshot (Projektfunktion brauchst Du nicht):https://forum.iobroker.net/topic/43856/json-string-oder-java-object-in-iobroker-struktur
https://forum.iobroker.net/topic/43856/json-string-oder-java-object-in-iobroker-struktur/9Ich hab Dir mal nur den Teil exportiert ohne die mqtt-In Node - das kannst ggf. selbst machen oder alternativ eine iobroker-in Node vorne dran hängen:
Hier der Flow zum Import - enthält dann automatisch die Subflow Node mit Beschreibung:
Standardmässig werden die Datenpunkte nur als Read-Only Datenpunkte angelegt - macht eigentlich auch Sinn, da man damit ja nichts steuert, sondern Informationen liest. Willst Du das alle Datenpunkte, die von dem Flow angelegt werden beschreibbar sind, musst Du das in der iobroker-out Node angeben:
Ausserdem bekommt man glaub sogar Warnungen im LOG wenn man ReadOnly Felder beschreiben will. Ganz blicke ich das auch nicht - alles Admin5 Änderungen.
EDIT2: Na anscheinend kann man die Datenpunkte doch ReadOnly lassen und sie werden es gibt keine Fehlermeldungen wenn der Adapter die Datenpunkte beschreibt. Vielleicht wurde da was geändert im Admin5.Und wie gesagt in der Hilfe zu der Subflow Node habe ich die Funktionsweise nochmals kurz beschrieben:
Die Bäume werden also als msg.top Datenpunkte ALLE unter 0_userdata.0 angelegt. Wenn Du diese selbst wieder als mqtt topics über die mqtt-out Nodes beschreiben willst, musst halt über eine Change Node die topics wieder anpassen!
Wenn Du nun natürlich mehrere Geräte unter userdata.0 aufgesplittet haben willst brauchst nur den vorderen Teil zu ändern, der hintere kann gleich bleiben.
Zur Veranschaulichung habe ich mal die zugehörigen Nodes gruppiert und beschriftet:
Man kann aber auch alle 5 Nodes gruppieren und pro Device machen - macht wahrscheinlich keinen Unterschied.
EDIT: Sorry hatte die Code-Tags beim Flow vergessen, habe ich nun nachgetragen, damit man das leichter kopieren kann. Ich hasse das selbst, wenn man da ewig scrollen muss anstelle "Select All" und dann kopieren.
-
@dos1973 Ach und ändere doch mal die Überschrift vom "Mqqt" in "Mqtt" - ansonsten findet das niemand und schaut grauslig aus.
-
@mickym sagte in Mqtt best practice:
@dos1973 Ach und ändere doch mal die Überschrift vom "Mqqt" in "Mqtt" - ansonsten findet das niemand und schaut grauslig aus.
habe ich gemacht.
und ich habe auch die ganzen Infos reinbekommen. Schon toll, wie schnell und einfach.
ok, gebe zu, dass ich momentan noch nicht alles verstehe - sondern nur nachbaue. Aber beeindruckt mich.
aber ich muss den DP (mqtt.0.shellies.command) aktiv triggern über ein cronjob z.b alle 30 Sekunden damit die Werte aktualisiert werden?
mit dem Wert "update" und "announce"
richtig?
-
@dos1973 Nein das würde ich auf keinen Fall machen. Die wichtigsten Werte wie Schaltzustände und Verbräuche und Temperaturen werden zeitnah aktualisiert.
Das ist sinnloser Netzverkehr und belastet den ioBroker und die Shellies unnötig.
Ich würde das announce Kommando allenfalls als eine Art Refresh Button ansehen, das man mal auf Bedarf drückt. Alles wichtige aktualisiert sich on demand und selbstständig. Die Intervalle kannst Du über die mqtt Parameter im Shelly einstellen.
Im Prinzip gibt es neben den Schaltzuständen also relays, lights, noch den Stromverbrauch zu überprüfen und den announce Datenpunkt (enthält Benachrichtigung über FW Updates). Damit ist eigentlich das wichtigste abgedeckt.
Ansonsten würde ich den Info DP eben nur auf Bedarf holen oder wenn Du unbedingt willst, in wesentlich längeren Zeitabständen (alle Stunde oder so).
-
@dos1973
Noch eine Anmerkung meinerseits. Ich persönlich nutze die Aufspaltung des JSON strings in einzelne Objekte nicht, da weder der Informationsgehalt steigt und Du nun aus 1 Objekt 50 Objekte machst. Gut es wird übersichtlicher dargestellt aber auch der Zugriff auf Eigenschaften eines JavaScript Objekts ist keine Hexerei und spart Ressourcen. -
ja, ich hab auch recht schnell gemerkt, ich brauch die Infos eigentlich nicht.
Ich hätte gerne einezelne Werte daraus, IP, WLAN, RSSI etc. ein paar ausgewählte.ich habe eben den Shelly Motion eingebunden, bei dem muss ich den Node-Red Ansatz fahren...
der bietet nur diese DP an.
im Status sind dann die Werte die ich für die Logik brauche, insbesondere "motion" um die Beleuchtung ein/ auszuschalten.
was mir aber heute extrem auffällt, diverse Adapter starten immer wieder neu, Zigbee, Harmony... auch der Shelly Adapter. Kann das daran liegen dass dort noch hinreferenziert wird, aber eben zT noch fehlerhaft...?
-
@dos1973 Grundsätzlich kannst Du die Parameter auch direkt abgreifen.
Wenn Du aus dem status was brauchst - dann bekommst mit der json Node ein Javascript objekt und kannst dann über payload.eigenschaft direkt darauf zugreifen. Aber egal - ich hab den Flow ja gebastelt, wenn man das in einzelnen Datenpunkten haben will.
Shelly Adapter kenn ich nicht, Harmony oder Zigbee kommunizieren ja gar nicht über mqtt - das hat meines Erachtens überhaupt nichts mit Deinen Umstellungen zu tun.
Wenn Du einzelne Werte brauchst kannst ja die Objekte selbst rauslösen bevor Du sie in die Subflow Node speist.
Aber wie gesagt auf einzelne Werte greifst einfach nach dem json Node direkt zugreifen
-
ich dachte ...ich änder mal "schnell" auf Mosquitto
das ganze ist ganz schön in Arbeit ausgeartet... und ich bin noch nicht fertig.Aber ich bin damit echt zufrieden.
-
jetzt habe ich doch ein mittelschwere Problem in meiner VIS.
Ich benutze den DP zum schalten
mqtt.0.shellies.Küche_Lichtschalter.relay.0.command
aber die Werte Syncen sich nicht zueinander
mqtt.0.shellies.Küche_Lichtschalter.relay.0
d.h, wenn jemand das Licht am Schalter ausmacht, wird mein State nicht aktualisiert... das wäre für mich ein NoGo.
irgendeine Idee?
-
@dos1973 Wie gesagt, dass kann nicht der gleiche Datenpunkt sein.
Wenn Du den Status UND das Kommando in einem Datenpunkt behandeln willst musst Du das über einen selbst erstellten Datenpunkt machen. Das hat aber mit mqtt-Adapter nichts zu tun, sondern da hättest Du immer ein Problem. Wichtig ist, dass der Status auch bei dem Schalter immer den Status des relays wiedergibt. Ich hab es mit dem Flow sauber mit dem ACK Flag gemacht. Man kann auch nur die Änderungen filtern, aber dann läuft die Schleife logisch 2 mal durch
Der aktuelle State steht immer (also egal ob Du den Shelly am Schalter oder logisch schaltest) in
mqtt.0.shellies.Küche_Lichtschalter.relay.0
das commando ist was anderes und ist nur zum Setzen eines Kommandos da.
Sprich wenn Du einen eigen Datenpunkt erstellst, dann kannst Du es in einem eigenen Datenpunkt machen und mit dem ACK-Flag arbeiten.
VIS schickt immer ohne ACK Flag und nur auf das darfst Du dann reagieren:
Diesen DP bindest Du in Deine VIS ein.
Wenn Du mit NodeRed arbeitest kannst Du dann folgenden Flow nutzen:
Die Visualisierung sollte also von der eigentlichen Steuerung getrennt werden. Beim Shelly Adapter hat der Adapter einen Datenpunkt nutzen können, weil er selbst über das ACK Flag gearbeitet hat. Sprich das ACK Flag von VIS wurde nicht gesetzt und der Adapter wusste, er musste schalten.
Wenn der Shelly hingegen gemeldet hat, dass er geschaltet hat, hat er das mit ACK Flag gesetzt und somit konnte er selbst eine Endlosschleife verhindern. Du baust nun diese Logik mach.Das ist grundsätzlich so. Auch wenn Du mit Tasmota arbeitest sind die Kommandodatenpunkte und die Zustandsdatenpunkte immer verschieden, sonst würdest Du immer in einer Endlosschleife landen.
In der iobroker-out Node setzt Du das ACK Flag durch den Type:
Type value = ACK gesetzt also Wert bestätigt
Type command = ACK nicht gesetzt. also Wert unbestätigt
In diesem Fall ist es halt deshalb nötig über einen eigenen Datenpunkt zu arbeiten, weil Du 2 verschiedene Möglichkeiten zum Schalten hast. Würdest Du nur über die VIS schalten, wäre der Status ja in der Regel immer mit der Schalterstellung identisch.
Ich schalte sogar über 3 Möglichkeiten- über meine Visualisierung (Dashboard)
- über den physischen Schalter
- über Siri - bzw. Yahka Adapter (oder Alexa etc.)
Insofern nimmt der Adapter schon einiges an Arbeit ab, aber es sind keine unüberwindlichen Hindernisse.
-
ich stehe eben auf dem Schlauch.
ich habe dein Flow importiert, habe einen DP "0_userdata.0.Wohnung.Status.Shellys.Küche" angelegt und die Flows verbunden.der DP aktualisiert sich wie der Shelly On/off , aber ich kann darüber nicht schalten?
Das mit dem ACK - wo finde ich diese Einstellung?
-
Du schickst über Deine VIS kein on/off sondern true/false
ich hab es Dir markiert.
-
@dos1973 sagte in Mqtt best practice:
Das mit dem ACK - wo finde ich diese Einstellung?
Habe ich Dir doch lange beschrieben. In der iobroker out Node - value (ACK =true) - command (ACK = false).
VIS schickt nie ein ACK=true sondern immer ACK=false.
-
@mickym
sorry, ich verstehe momentan gar nicht, was du mir versuchst zu erklären.ich hatte gedacht verstanden zu haben, dass ich aus der userdata DP die Schaltung mittels true/ falls machen kann. Das klappt nicht, der DP aktualisiert, aber das hilft mir ja nicht für mein VIS
-
@dos1973 Ich verstehe Dich nicht:
Du schaltest doch mit on und off hier? Du musst nur als Object ID den 0_userdata DP eintragen.
Ansonsten wenn vis nur mit true und false umgehen kann, was ich aber nicht glaube - dann kannst natürlich übersetzen - aber eigentlich dachte ich, dass Du über die VIS direkt on und off schickst.
-
@mickym
ich habe es gefunden, war fast richtig...ich hatte den DP
0_userdata.0.Wohnung.Status.Shellys.Küche
als Logikwert angelegt, damit ging es nicht. Ich hab den jetzt als Zeichenkette angelegt und kann dort mit on/ off jetzt de state schalten und der wird auch gesynct
-
@dos1973 sagte in Mqtt best practice:
@mickym
ich habe es gefunden, war fast richtig...ich hatte den DP
0_userdata.0.Wohnung.Status.Shellys.Küche
als Logikwert angelegt, damit ging es nicht. Ich hab den jetzt als Zeichenkette angelegt und kann dort mit on/ off jetzt de state schalten und der wird auch gesynct
Tja ein Logikwert kennt kein on oder off.
- Aber ich habs ja zum Glück an der Statusmeldung der iobroker out Node erkannt, dass Du ein true sendest.
- Ist ja immer etwas schwierig - Fehlersuche aus der Ferne zu machen.
-
@dos1973 Im Übrigen kannst Du generell auch alles auf true/false übersetzen - das ist unter Umständen später einfacher, wenn Du Massenauswertungen machen willst - alla ist alles ausgeschaltet etc.
Wenn Du also den userdata_0 Datenpunkt lieber als Logikwert haben willst dann setzt halt 2 Change Nodes in den Flow:
Wichtig ist halt das die Stringkonvertierung im Adapter ausgeschaltet ist - aber das haben wir ja schon früher im Thread besprochen und gemacht.
-
@mickym
das ist ja heute mein ALLER erster Kontakt mit node-red... muss eigentlich für alle ein neuen "flow" anlegen, oder kann ich zum Beispiel für das Vis schalten alle in ein flow machend -
@dos1973 Kannst alles in einen Flow machen.
Ich habe mein Flows halt bissi thematisch gegliedert - damit man es später wieder findet. Zum Beispiel Lampen etc. Im Gegenteil über einen gemeinsamen Flow - kannst Du dann über Variablen zwischen den verschieden triggern und flows (also etwas von links nach rechts
) - bestimmte Dinge gemeinsam steuern.
Du kannst auch mit Gruppe arbeiten, um das dann auch noch optisch etwas hervorzuheben, wie ich in dem anderen Beispiel gezeigt habe.
Ich wollte Dich aber nicht überreden - vielleicht hätte Dir ein Blockly- Fan das auch alles implementiert.
Aber - wenn Du Dich darauf einlässt, was Du ja tust
- dann kannst ja selbst entscheiden, welches Tool für Dich einfacher ist.