NEWS
Mqtt best practice
-
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.
-
@mickym
ich versuche mich einfach dran... wie alles andere. ich hoff du bleibst weiter so hilfsbereit und geduldig -
@dos1973 Ach - wenn Du manche Threads hier durchliest - dann wirst Du sehen, dass es lange braucht bis mir der Geduldsfaden reißt, außer jemand gibt sich keine Mühe oder ich schreibe Dinge 10 mal.
Wenn das Dein erster Kontakt mit NodeRed ist (importieren) und solche Dinge konntest Du ja anscheinend problemlos,
dann achte mal unten bei den Flow auf diese Schaltflächen.Mit dem aufgeschlagenen Buch siehst Du quasi die ganze Flowseite als Übersicht - siehtst bei mir ist der Lampenflow schon ziemlich voll.
Dann siehst Du links oben so ein weißen Fenster mit dem Du Dich durch den Flow bewegen kannst.
Mit dem + und - kannst Du den Flow zoomen oder verkleinern - das ist praktisch um Flows zu kopieren - gerade wenn die Logik identisch ist. Das Zoomen wirkt sich aber nur auf das Flowfenster aus und nicht auf den gesamten Browser - was in diesem Fall sehr praktisch ist.
Mit O stellst dann wieder auf 100%.
-
@dos1973 Was ich selbst viel zuwenig mache, ist die Gruppierfunktion zu benutzen.
Damit kannst zugehörige Nodes mit einem Rahmen zusammenfassen und dann beschriften und mit einer Hintergrundfarbe belegen. Damit findet man sich auf so einer Flowseite später leichter zurecht.
Man kann dann z.Bsp. für bestimmte Räume immer die gleiche Farbe verwenden usw.
Aussderdem kann man so eine Gruppe anklicken und dann einfach mit Strg+C und Strg+V die Gruppe kopieren und dann nur noch die entsprechenden Datenpunkte anpassen.
Über die Kommentar Nodes - kannst auch etwas Übersicht gewinnen.
In der Kommentar-Node kannst Du dann eigene Notizen schreiben, um später vielleicht auch noch zu verstehen, warum Du was wie gemacht hast.
Wenn Du später auf das i (information Icon) klickst,
dann kannst Du Dir diese Beschreibung ansehen:
-
@mickym
ich bekomme das mit true/false nicht geregelt.
eigentlich ...müsste doch der rote Pfeil, jetzt Konvertierung von true nach on machen??? -
@dos1973 Hast Du den Datenpunkt von String wieder auf Logikwert umgestellt?