Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. Mqtt best practice

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    Mqtt best practice

    This topic has been deleted. Only users with topic management privileges can see it.
    • D
      dos1973 @mickym last edited by dos1973

      @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.
      Bildschirmfoto 2021-09-23 um 16.27.08.png

      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?

      Bildschirmfoto 2021-09-23 um 16.41.58.png

      mickym 2 Replies Last reply Reply Quote 0
      • mickym
        mickym Most Active @dos1973 last edited by mickym

        @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).

        1 Reply Last reply Reply Quote 0
        • mickym
          mickym Most Active @dos1973 last edited by

          @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.

          D 1 Reply Last reply Reply Quote 0
          • D
            dos1973 @mickym last edited by

            @mickym

            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.
            Bildschirmfoto 2021-09-23 um 20.45.35.png

            im Status sind dann die Werte die ich für die Logik brauche, insbesondere "motion" um die Beleuchtung ein/ auszuschalten.

            Bildschirmfoto 2021-09-23 um 20.46.23.png

            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...?

            mickym 1 Reply Last reply Reply Quote 0
            • mickym
              mickym Most Active @dos1973 last edited by mickym

              @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.

              76468f60-7142-4412-ac44-54b56ef5d205-image.png

              67d9f775-d6ac-4e94-83a2-36d95b945727-image.png

              Aber wie gesagt auf einzelne Werte greifst einfach nach dem json Node direkt zugreifen

              019052cf-058c-4711-a89c-197404345d0c-image.png

              D 1 Reply Last reply Reply Quote 0
              • D
                dos1973 @mickym last edited by

                @mickym

                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.👍

                D 1 Reply Last reply Reply Quote 0
                • D
                  dos1973 @dos1973 last edited by

                  @mickym

                  jetzt habe ich doch ein mittelschwere Problem in meiner VIS.

                  Bildschirmfoto 2021-09-23 um 23.38.13.png

                  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?

                  mickym 1 Reply Last reply Reply Quote 0
                  • mickym
                    mickym Most Active @dos1973 last edited by mickym

                    @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:

                    624c3372-2bb4-4822-9535-cf9ede66d0f9-image.png

                    [
                       {
                           "id": "3e9c2889.5dd6e8",
                           "type": "ioBroker in",
                           "z": "169f5b00.a13415",
                           "name": "",
                           "topic": "0_userdata.0.Lichtschalter",
                           "payloadType": "value",
                           "onlyack": "",
                           "func": "rbe",
                           "gap": "",
                           "fireOnStart": "false",
                           "x": 280,
                           "y": 480,
                           "wires": [
                               [
                                   "39d2398d.c05576"
                               ]
                           ]
                       },
                       {
                           "id": "39d2398d.c05576",
                           "type": "switch",
                           "z": "169f5b00.a13415",
                           "name": "Nur ACK = False",
                           "property": "acknowledged",
                           "propertyType": "msg",
                           "rules": [
                               {
                                   "t": "false"
                               }
                           ],
                           "checkall": "true",
                           "repair": false,
                           "outputs": 1,
                           "x": 550,
                           "y": 480,
                           "wires": [
                               [
                                   "68e40785.91af98",
                                   "f19094f3.f5a0a8"
                               ]
                           ]
                       },
                       {
                           "id": "68e40785.91af98",
                           "type": "ioBroker out",
                           "z": "169f5b00.a13415",
                           "name": "",
                           "topic": "mqtt.0.shellies.Küche_Lichtschalter.relay.0.command",
                           "ack": "false",
                           "autoCreate": "false",
                           "stateName": "",
                           "role": "",
                           "payloadType": "",
                           "readonly": "",
                           "stateUnit": "",
                           "stateMin": "",
                           "stateMax": "",
                           "x": 910,
                           "y": 480,
                           "wires": []
                       },
                       {
                           "id": "8c63547a.3b2288",
                           "type": "ioBroker in",
                           "z": "169f5b00.a13415",
                           "name": "",
                           "topic": "mqtt.0.shellies.Küche_Lichtschalter.relay.0",
                           "payloadType": "value",
                           "onlyack": "",
                           "func": "all",
                           "gap": "",
                           "fireOnStart": "false",
                           "x": 320,
                           "y": 580,
                           "wires": [
                               [
                                   "6587948d.dc03bc"
                               ]
                           ]
                       },
                       {
                           "id": "6587948d.dc03bc",
                           "type": "ioBroker out",
                           "z": "169f5b00.a13415",
                           "name": "",
                           "topic": "0_userdata.0.Lichtschalter",
                           "ack": "true",
                           "autoCreate": "false",
                           "stateName": "",
                           "role": "",
                           "payloadType": "",
                           "readonly": "",
                           "stateUnit": "",
                           "stateMin": "",
                           "stateMax": "",
                           "x": 720,
                           "y": 580,
                           "wires": []
                       },
                       {
                           "id": "f19094f3.f5a0a8",
                           "type": "debug",
                           "z": "169f5b00.a13415",
                           "name": "",
                           "active": true,
                           "tosidebar": true,
                           "console": false,
                           "tostatus": false,
                           "complete": "false",
                           "statusVal": "",
                           "statusType": "auto",
                           "x": 790,
                           "y": 440,
                           "wires": []
                       },
                       {
                           "id": "9c870f79.6d6f5",
                           "type": "inject",
                           "z": "169f5b00.a13415",
                           "name": "",
                           "props": [
                               {
                                   "p": "payload"
                               }
                           ],
                           "repeat": "",
                           "crontab": "",
                           "once": false,
                           "onceDelay": 0.1,
                           "topic": "",
                           "payload": "off",
                           "payloadType": "str",
                           "x": 430,
                           "y": 620,
                           "wires": [
                               [
                                   "6587948d.dc03bc"
                               ]
                           ]
                       },
                       {
                           "id": "56ee62e6.5a107c",
                           "type": "comment",
                           "z": "169f5b00.a13415",
                           "name": "Aktualisierung durch VIS - wenn ACK false",
                           "info": "",
                           "x": 340,
                           "y": 420,
                           "wires": []
                       },
                       {
                           "id": "b137c5d6.0ccff8",
                           "type": "comment",
                           "z": "169f5b00.a13415",
                           "name": "Aktualisierung durch den Shelly",
                           "info": "",
                           "x": 310,
                           "y": 540,
                           "wires": []
                       }
                    ]
                    

                    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:

                    0dfaa83a-4b95-4b29-a589-0bb1609f2bb5-image.png

                    Type value = ACK gesetzt also Wert bestätigt

                    388b6b00-75b9-40a1-8372-585a18a248f8-image.png

                    Type command = ACK nicht gesetzt. also Wert unbestätigt

                    7d0e0761-709d-4ed4-b41b-170aef2c9134-image.png

                    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. 😇 😁

                    D mickym 2 Replies Last reply Reply Quote 0
                    • D
                      dos1973 @mickym last edited by dos1973

                      @mickym

                      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.

                      Bildschirmfoto 2021-09-24 um 00.23.28.png

                      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?

                      mickym 1 Reply Last reply Reply Quote 0
                      • mickym
                        mickym Most Active @mickym last edited by

                        Du schickst über Deine VIS kein on/off sondern true/false

                        c3eeb089-5532-4197-af1e-8a794b1af906-image.png

                        ich hab es Dir markiert.

                        1 Reply Last reply Reply Quote 0
                        • mickym
                          mickym Most Active @dos1973 last edited by

                          @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.

                          D 1 Reply Last reply Reply Quote 0
                          • D
                            dos1973 @mickym last edited by

                            @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

                            mickym 1 Reply Last reply Reply Quote 0
                            • mickym
                              mickym Most Active @dos1973 last edited by mickym

                              @dos1973 Ich verstehe Dich nicht:

                              c6fc4608-39ff-44ce-95e2-1b6d98eeabe4-image.png

                              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.

                              D 1 Reply Last reply Reply Quote 0
                              • D
                                dos1973 @mickym last edited by dos1973

                                @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

                                mickym 2 Replies Last reply Reply Quote 0
                                • mickym
                                  mickym Most Active @dos1973 last edited by

                                  @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. 😉

                                  1 Reply Last reply Reply Quote 0
                                  • mickym
                                    mickym Most Active @dos1973 last edited by mickym

                                    @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:

                                    152b96b5-f19c-4a0c-a22d-8825adc36812-image.png

                                    d10bb7fb-e45f-46a9-b57e-83c50f42079e-image.png acb3e6d0-af0c-45c9-a9d4-e7bf477d04a0-image.png

                                    Wichtig ist halt das die Stringkonvertierung im Adapter ausgeschaltet ist - aber das haben wir ja schon früher im Thread besprochen und gemacht. 🙂

                                    D 1 Reply Last reply Reply Quote 0
                                    • D
                                      dos1973 @mickym last edited by

                                      @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

                                      mickym 1 Reply Last reply Reply Quote 0
                                      • mickym
                                        mickym Most Active @dos1973 last edited by mickym

                                        @dos1973 Kannst alles in einen Flow machen.

                                        c7e3b3e5-aa4a-4863-926e-e761d35dda88-image.png

                                        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.

                                        D 1 Reply Last reply Reply Quote 0
                                        • D
                                          dos1973 @mickym last edited by

                                          @mickym
                                          ich versuche mich einfach dran... wie alles andere. ich hoff du bleibst weiter so hilfsbereit und geduldig 😉 😉

                                          mickym 2 Replies Last reply Reply Quote 0
                                          • mickym
                                            mickym Most Active @dos1973 last edited by

                                            @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.

                                            253c647f-420d-4f5b-b81f-6e836cd75ef8-image.png

                                            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%.

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate
                                            FAQ Cloud / IOT
                                            HowTo: Node.js-Update
                                            HowTo: Backup/Restore
                                            Downloads
                                            BLOG

                                            830
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

                                            mosquitto mqtt shellys
                                            6
                                            136
                                            9936
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo