NEWS
Mqtt best practice
-
@dos1973 Gehe auf Instanzen und in die Einstellungen Deiner Admin Instanz:
Mach den Haken Alte Benutzeroberfläche an, dann BrowserrefreshDann legst die Datenpunkte wie früher an.
Dann machst den Haken wieder raus und hast wieder die Admin5 Oberfläche.Anschließend lässt Du das Skript drüber laufen, das legt dann aus den fehlenden Objekten Verzeichnisobjekte an.
Status meldet der Shelly von selbst den brauchst nicht anlegen. Über den Status sendet der Shelly einen JSON mit Einstellungen
Den status scheint es nur bei dem DImmer zu geben.
-
@mickym
Ok, danke erstmal. Das kann ich erst morgen wieder versuchen.Melde mich morgen abend nochmals
Noch eine Frage:
Das script führe ich script Adapter aus? -
Falls Dich das interessiert, hier habe ich die Problematik mit dem Admin5 und mqtt ausführlich diskutiert:
https://forum.iobroker.net/topic/46851/datenpunkte-allgemein-und
und gibt inzwischen auch ein github issue
https://github.com/ioBroker/ioBroker.admin/issues/1067
Ich hoffe nur nicht - dass das Prio 99 bekommt, da nur als "Enhancement" und nicht als Bug akzeptiert.
-
@dos1973 sagte in Mqqt best practice:
Noch eine Frage:
Das script führe ich script Adapter aus?Ja unter Scripts
-
@mickym
ich muss nochmals fragen, was das script macht?!?nachdem ich den admin vom 5 auf 4 umgestellt habe, kann ich die states anlegen welche ich benötige. ich hab zwar das script ausgeführt - aber ich habe nicht verstanden warum ich das machen muss.
bei shelly 2.5 als Rollo habe ich jetzt noch diese DP angelegt
mqtt.0.shellies.Wohnzimmer_Rollo_links.roller.0.command.pos
command: für hoch/runter/stop
pos: für die genaue Positionsfahrtmir gefällt nicht so gut dass ich states manuell anlegen muss um die gerate zu steuern.
Wenn ich irgendwann mal eine Baum lösche und vergesse mir zu notieren was da war, dann geht die Suche wieder los... -
@dos1973 sagte in Mqqt best practice:
@mickym
ich muss nochmals fragen, was das script macht?!?nachdem ich den admin vom 5 auf 4 umgestellt habe, kann ich die states anlegen welche ich benötige. ich hab zwar das script ausgeführt - aber ich habe nicht verstanden warum ich das machen muss.
Das Skript legt fehlende Objekte an, die erst seit Admin5 nötig sind. Das heißt, wo vorher das Stift-Symbol gefehlt hat (hast Du ja bestätigt), sollte nun ein Stiftsymbol vorhanden sein.
Dann ist relay nun auch als Objekt Verzeichnis und Du solltest nun wie von mir ursprünglich beschrieben durch Markieren des relay Datenpunktes über das + Datenpunkte hinzufügen können.
Das Skript legt also bei fehlende Objekten, Objekte vom Typ "Folder" an.bei shelly 2.5 als Rollo habe ich jetzt noch diese DP angelegt
mqtt.0.shellies.Wohnzimmer_Rollo_links.roller.0.command.pos
command: für hoch/runter/stop
pos: für die genaue PositionsfahrtJa das passt:
mir gefällt nicht so gut dass ich states manuell anlegen muss um die gerate zu steuern.
Wenn ich irgendwann mal eine Baum lösche und vergesse mir zu notieren was da war, dann geht die Suche wieder los...Nun das ist generell bei mqtt so. Es werden nur die Topics geschrieben, die auch veröffentlicht wurden und ein Gerät veröffentlicht nicht die Topics auf die es hört, da dies zu einer Endlosschleife führen würde.
Generell empfiehlt es sich, dass Du ggf. noch Aliase anlegst, damit hast Du auch dokumentiert, welche Datenpunkte Du zum steuern verwendest und kannst die Geräte im Fall eines Austauschs einfach austauschen.
Du kannst ja auch jeden Shelly Typ - die Objektstruktur exportieren, um quasi eine Vorlage zu haben.
Wenn Du willst kannst Dir ja auch ein kleines Script schreiben, dass Dir über den mosquitto Client alle Datenpunkte anlegt oder Du legst die Datenpunkte über Deine Logikmaschine an, wenn das geht.
Im NodeRed kannst zum Beispiel einfach angeben, dass Datenpunkte erstellt werden, wenn sie nicht existieren.
Alles nur ein paar Anregungen. Und wie gesagt ist ja nur Einmalaufwand.
-
das mit den Skripten ist so eine Sache
bin da nicht so bewandert.das mit den Alias wäre natürlich jetzt noch am Anfang sinnvoll... muss ich mir auch mal ansehen, welches da der beste Adapter ist, da gibts ja, meine ich auch inzwischen verschiedene Optionen.
-
@dos1973 Ich kann Dir nur den empfehlen, der wirklich mit dem Alias arbeiten und würde von dem anderen Adapter abraten.
- Ohne jetzt Namen zu nehmen.
Dieser Adapter legt wirkliche Aliase unter alias.0 an und damit werden wirklich die Systemfunktionen genutzt und nicht Funktionen in dem Adapter selbst - wie das die Konkurrenz macht.
Über den Alias kannst dann auch solche Übersetzungen realisieren, dass Du zum Beispiel ON in true und OFF in false übersetzen lassen kannst, wenn Dir das sinnvoll erscheint:
-
Ich habe aber gerade gesehen, dass Du bei Deinen Shellies sowieso eigene mqtt-Prefixe nutzt. Also Küche etc..
Dann brauchst eigentlich keinen Alias. Wenn Du tatsächlich mal ein Gerät austauschen musst, dann kannst Du ja den gleichen Prefix wieder verwenden und musst weder in Deinen Logikmaschinen noch in Deiner Visualisierung was ändern.
-
@mickym
auch so einer der spät basteltja, ich bin noch am ausprobieren und hab da mal mit den Prefixen rumprobiert.
ich weiß eben noch nicht was mir u.U. Vorteile / Nachteile bringt. spiele derzeit auch mit dem Alias Adapter -
@dos1973 Ja ich gehöre eher zu den Eulen, als zu den Lerchen.
Für Deine Shellies alleine ist der Vorteil eigentlich marginal.
Man kann halt eine ähnliche Struktur über verschiedene Gerätetypen machen.
Unten habe ich Dir ja im Screenshot gezeigt, wie man zum Beispiel bei Lesen on in true, off in false übersetzt.
Man kann aber auch zum Beispiel einzelne Werte direkt aus einem JSON Objekt rauslösen.
Der Zustand bzw. das Dimmlevel, sprich die Helligkeit des Shelly Dimmers wird ja im status Wert ausgegeben:Das kann man dann im Alias direkt rauslösen
In der Alias Definition gibt man dafür den Befehl in Javascript zum Lesen ein.
Was allerdings mit einem Alias nicht geht, bei Lesen und Schreiben unterschiedliche Datenpunkte als Quelle angeben!!
-
@mickym
du überforderst michscheinst die Möglichkeiten ja wirklich extrem auszunutzen.
Ich fange jetzt an die Shellys vom Shelly Adapter auf den Mosquitto umzuziehen.
Jetzt weiß ich nur nicht, ob ich mir noch die Alias Struktur geben soll, weil ich ja ale VIS und Script ebenfalls "anfassen" muss...ich mach mal für heute Schluss und schlaf mal eine Nacht drüber.
-
@dos1973
Also wie gesagt mit Deinem benutzerspezifischen Prefix - musst Du es wegen den Shellies aus meiner Sicht nicht machen.Schlaf gut - und möge Dich Dein Schlaf erleuchten.
-
@mickym
nochmals ich, gibt es noch einen einfach Trick/ Vorgehensweise um Infos mittels Mqqt aus dem shelly Status abzufragen und als DP anzulegen?und manche Shellys haben noch den Datenpunkt "announce", da stehen auch einige infos drin, / manche DP sind leer aber eben nicht überall gleich die Regel dazu habe ich noch nicht verstanden
-
@dos1973 Du kannst direkt unter allen shellies nochmal einen Datenpunkt command anlegen oder bei den einzelnen shellies. Dort kann man dann mit announce die shellies zwingen ihren status im info Datenpunkt abzulegen oder bei Bedarf kann man das nutzen um die Firmware zu aktualisieren.
siehe: https://shelly-api-docs.shelly.cloud/gen1/#common-mqtt-commands
Im Info-Datenpunkt findest in der Regel fast alle Infos zu dem Shelly in einem JSON zusammengefasst. So auch ob es ein FW Update gibt, welche FW Version etc.
Mit announce in dem command Punkte - entweder beim Einzelgerät oder für alle werden die info DP aktualisiert, mit update die normalen states, mit update_fw kannst Du Firmwareupdates anstossen.
Aus dem Link siehst, dass die announce Datenpunkte eher alt sind und bis zur FW. 1.6.x genutzt wurden, ab Version 1.8.x wird Info genutzt. Aktuell siehst ja an meinem Screenshot sind wir bei einer FW Version 1.11.x
Und wenn Du mit NodeRed arbeiten würdest könntest ja meinen Flow nutzen der daraus einzelne Datenpunkte unter userdata macht - (Wenn derzeit auch mit Nacharbeit wegen Admin5). Zeig es Dir mal an einem Beispiel. Theoretisch könnte Dir so ein Flow auch selbst den Info DP unter mqtt aufdröseln.
-
@mickym sagte in Mqqt best practice:
Und wenn Du mit NodeRed arbeiten würdest könntest ja meinen Flow nutzen der daraus einzelne Datenpunkte unter userdata macht - (Wenn derzeit auch mit Nacharbeit wegen Admin5). Zeig es Dir mal an einem Beispiel. Theoretisch könnte Dir so ein Flow auch selbst den Info DP unter mqtt aufdröseln.
Mit diesem kleinen Flow - könntest Du dann alle states aus dem Info Datenpunkt aufdröseln:
Dann muss man halt wieder das javascript drüber jagen - dieses Mal über userdata - damit einmalig die fehlenden Objekte angelegt werden. NodeRed kann im Moment nur states und keine Objekte anlegen.
Fehlende Stiftsymbole !!!
Das Skript macht dann aus allen fehlenden Objekten - Folderobjekte:
Ist das aber einmal erledigt, dann werden diese Datenpunkte mit Aktualisieren des Info Datenpunktes automatisch aktualisiert.
Ich habe deshalb niemals verstanden, warum man Adapter nutzt, die kaum was anderes machen, als kompakte JSON-String Datenpunkte in einzelne Datenpunkte zerlegt. OK man muss keine Datenpunkte selbst anlegen, wenn man Kommandos verschickt.
- Punkt gegen mqtt.
Bei Bedarf kann man sich ja auch nur einzelne Datenpunkte aus dem JSON rausholen und in einem Alias beispielsweise abspeichern (habe ich ja vorher schon mal gezeigt, wie das geht). -
In diesem Info Datenpunkt bekommt man in meinen Augen mind. soviel Infos wie in dem Adapter:
So siehst Du zum Beispiel, ob der Shelly gerade mit einem FW Update beschäftigt ist oder auch RAM Belegung ,die Güte des WLAN Signals, Uhrzeit des Shellies usw.
Uptime ist hier die Zeit in Sekunden (nicht Millisekunden
), seitdem das Gerät neu gebootet hat- also 548006 Sekunden sind in diesem Fall ca. 152 Stunden oder vor gut 6 Tagen.
-
@dos1973
Falls Du übrigens mal den Shelly über Deine VIS und nicht das WEB-Interface konfigurieren willst und Du feststellst es geht nicht über MQTT, dann bleibt Dir immer noch die HTTP Schnittstelle, mit der kannst quasi alles machen.Um zum Beispiel den Zeitserver zu ändern stehen Dir ja die unter settings beschriebenen Parameter zur Verfügung:
https://shelly-api-docs.shelly.cloud/gen1/#settingsIch hab das sowohl mit GET und POST Requests getestet und funktioniert wunderbar:
Die Get-Requests funktionieren zum Testen auch im Browser wunderbar:
Mit
kannst also zum Beispiel den SNTP Server setzen:
So nun hab ich aber glaube genug Möglichkeiten der Steuerung ohne Adapter aufgezeigt.
Ergänzend sei noch hinzugefügt: Natürlich kannst Du solche HTTP Requests auch über Blockly machen - aber ich bin da kein Fan von, deswegen habe ich hier nur begrenztes Wissen, aber dafür gibts ja dann andere hier an Board.
-
@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.
-
@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.