Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Error/Bug
    4. mqtt Adapter 4.0.7 Hohe CPU Load

    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 Adapter 4.0.7 Hohe CPU Load

    This topic has been deleted. Only users with topic management privileges can see it.
    • Homoran
      Homoran Global Moderator Administrators @Asgothian last edited by

      @asgothian sagte in mqtt Adapter 4.0.7 Hohe CPU Load:

      Ein Load von 2,8% - 3% ist vergleichbar wenig

      reden wir hier von cpu Last in % oder von load average, die über den Daumen die Anzahl Kerne nicht überschreiten sollte. Eine Load average von 3 wären dan etwa 75% Auslastung.

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

        Kann ich auch nicht bestätigen - ich vermute mal dass Du eine Endlosschleife drin hast, in dem Du Zustände publishst. Ggf. erst mit Änderung sodass das Verhalten nicht sofort auftritt. Und glaube mir, bei mir läuft einiges über den Adapter

        120603ef-bd90-443d-aacd-2f423bc1674b-image.png

        und meine CPU Last ist im grünen Bereich

        dbbff9c4-b7cf-49f1-aa7e-e710f970f996-image.png

        Bei sind es max . 50% und ja dann habe ich vielleicht ein Verzögerung von 1-2s

        67e74cac-48b3-4c49-8da8-f141834c8de7-image.png

        Dazu läuft auch noch ein Desktop mit Firefox auf dem Raspberry - der ca. 2-3% Dauerlast erzeugt. Also wäre ich in Ruhe bei ca. 10% - was im Vergleich zu dem was bei Dir ohne mqtt läuft, ja sonst vergleichsweise hoch ist.

        Ich weiß aber das ist der DVD Adapter - alle Viertelstunde und der Linux Device Adapter den ich inzwischen auf 35 Minuten eingestellt habe, sodass der nicht zur gleichen Zeit aktiv wird.

        Und das was hier drüberläuft über den mqtt-Adapter ist mehr oder weniger Grundlast - alle Shellies die alle 30s - ihren Momentanverbrauch melden etc.

        1 Reply Last reply Reply Quote 0
        • lakelounge
          lakelounge @Homoran last edited by

          @homoran also ich habe von einer CPU-Last von 85 - 100 % je Core und einer Load von 2,8 bis über 3 gesprochen.

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

            @lakelounge sagte in mqtt Adapter 4.0.7 Hohe CPU Load:

            @homoran also ich habe von einer CPU-Last von 85 - 100 % je Core und einer Load von 2,8 bis über 3 gesprochen.

            Klingt nach 100% Endlosschleife - nimm mal Zustände publishen raus.

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

              @lakelounge genau, zeig mal bitte die Einstellungen deines MQTT Adapters

              lakelounge 2 Replies Last reply Reply Quote 0
              • lakelounge
                lakelounge @BananaJoe last edited by

                @bananajoe gerne, sobald ich wieder Zuhause bin …

                1 Reply Last reply Reply Quote 0
                • lakelounge
                  lakelounge @BananaJoe last edited by

                  @bananajoe vielen Dank schon mal im Voraus für die Hilfe! Bei den Einstellungen lasse ich mir sehr gerne helfen. Bin eben angekommen und zum Glück ist die Auslastung heute über den Tag normal geblieben. Ich muss das weiter beobachten …

                  mqtt-settings.png

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

                    @lakelounge Tja wie ich vermutet habe - Zustände schicken und redudant wieder reinholen.

                    lakelounge* bei eigenen States (hier zeigt sich in meinen Augen, dass Du nicht wirklich weißt, was die Parameter bedeuten) - wegmachen - ich denke so einen Adapter gibts nicht. Und subscribe Patter # ist auch Käse, wenn man dahinter dann States eingrenzt. Mit # holst Du alles. Bei den eigenen States gehört max. noch die mqtt- Instanz also zum Beispiel mqtt.0.* - so wie es am Anfang drin stand rein. Wie gesagt bei der Konfig wundert mich das nicht - hat aber auch 0,0 mit der Adapterversion zu tun. Was Du unter Umständen machst - ist - dass Du damit im TR-04 Adapter rumpfuschst.

                    Ansonsten habe ich hier die Dinge zusammengefasst - ich weiss ja noch nicht mal ob Du Deinen Adapter als Broker oder Client betreibst: https://forum.iobroker.net/topic/57365/mqtt-broker-empfängt-daten-sendet-aber-nicht-an-client/8?_=1662032439387

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

                      @mickym Erst einmal vielen Dank für deine ausführliche Hilfe! Ich hatte weiter oben geantwortet, dass ich mosquitto als Broker benutze und ioBroker als Client. Danke für die Erklärung der Pattern! Ja, da wusste ich bei einigen, trotz Google-Suche nicht, was sie genau bedeuten. Bei der Konfig wundert mich nur, dass diese jetzt 2 Jahre funktioniert hat und mir dann 2 Mal die Performance davonfliegt wenn ich den 4.0.7 Adapter installiere. Aber das kann auch Zufall sein.

                      Danke dir und allen anderen in diesem Thread für deine/eure Hilfe!

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

                        @mickym @BananaJoe ich hab jetzt noch etwas weiter gesucht und poste das mal hier. Ich habe die mqtt-Einstellungen entsprechend eurer Tipps und Dokumentationen angepasst.
                        Nun ist im mqtt.2. Screenshot von @mickym die Checkbox „Sende auch Zustände (ack=true)" angeklickt. Das hab ich auch gemacht, weil ja die TR-04 Daten rausgeschickt sollen.

                        Ich habe zwei Delock-Steckdosen (mit Tasmota 12.1.1) im Einsatz. Bei einer davon laufen unter stat Tausende von Meldungen auf, wenn ich „Sende auch Zustände (ack=true)" anschalte (reproduzierbar):

                        delock.png

                        Hier der gesamte „Baum“ aus dem mqtt-Explorer:

                        switch01.png

                        Es ist „RESULT“, das immer zwischen "Command":"Unknown" und "ON" hin- und herschaltet. Das passiert bis zu 50.000 Mal in kürzester Zeit (da schließt sich der Kreis zur hohen Load vom Raspberry).
                        Ich schalte diese Steckdosen nicht über mqtt! Ich messe nur. Es gibt keine Skripte, die diese Steckdosen ansprechen etc.

                        Ich hab die Delock-Steckdose neugestartet, eine neue Firmware aufgespielt etc. die vielen Meldungen bleiben bzw. kommen immer wieder. Ich verstehe nicht ganz, wer den stat genau sendet. Die Meldungen laufen sogar auf, wenn die Steckdose grade neu startet.

                        Hat jemand eine Idee, warum das so ist?

                        Das einzige was ich im ioBroker mit der Steckdose mache ist folgendes Script, welches die Verbrauchsdaten in Datenpunkte einträgt.

                        on({id: 'mqtt.0.home.egw2.switch01.tele.SENSOR', change: 'any'}, function (obj) {
                            var mqttSwitch01val = getState('mqtt.0.home.egw2.switch01.tele.SENSOR').val;
                            var theValue;
                            try {theValue = JSON.parse(mqttSwitch01val);
                                var mqttSwitch01Power = theValue.ENERGY.Power;
                                var mqttSwitch01GesamtW = theValue.ENERGY.Total;
                            } catch (e) {
                               console.error('Cannot parse: ' + getState('mqtt.0.home.egw2.switch01.tele.SENSOR').val);
                            return;
                        }
                            setState('0_userdata.0.Energie.mqtt.switch01.power', mqttSwitch01Power, true);
                            setState('0_userdata.0.Energie.mqtt.switch01.Switch01VerbrauchGesamt', mqttSwitch01GesamtW, true);
                        });
                        

                        Ich weiss zwar jetzt, wie ich die hohe Load des Raspberry runterbringe, aber nicht, was genau das Problem verursacht und vor allem nicht, warum das immer nur mit dem 4.0.7 mqtt-Adapter auftritt.

                        Bin für alle Anregungen dankbar!

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

                          @lakelounge Das Problem ist - dass Du sowohl publishen willst - also auch Daten sammelst - das ist bei Senden von Zuständen Endlosschleifen vorprogrammiert.

                          Ich empfehle Dir wenn Du einen mosquitto Broker hast - genauso wie ich 2 Instanzen zu nehmen - eine um quasi Zugriff auf den gesamten Inhalt des Brokers zu haben - und die 2. Instanz um zu publishen.

                          In dieser Instanz wird der mosquitto abgebildet und einzelne States gepublished - die es nicht in einem Adapter gibt:

                          e6017a32-1713-4dc0-9494-7a9b5600670f-image.png

                          So sieht meine Instanz aus, um quasi dem Inhalt meines gesamten mosquitto Brokers im iobroker zur Verfügung zu haben - damit kannst auch einzelne States publishen indem Du einfach Datenpunkte anlegst.

                          Die 2. Instanzen dient dazu um ganze Objekt Bäume eines Adapters zum Beispiel tr-064 unter einem Präfix wie bei Dir zu publishen. Es wird aber nicht mehr importiert - deswegen gibts da ein Dummy als Präfix

                          Man kann die Zustände schicken - wenn Du keine Änderungen publishst. Nachdem das unter einem eigenen Präfix erfolgt, sollten Deine Geräte nichts mitbekommen. Ich mache das bewusst nicht, da mich alte Zustände nicht interessieren von der FritzBox.

                          d7c031e3-2305-4cca-be4f-7663edba6dcd-image.png

                          Also für die Zustände in der 2. Instanz geht das auch:

                          dedeb5a4-0dc5-48a2-83e0-2630c3d4c95e-image.png

                          Die Instanz mit der Du aber nur den mosquitto abbilddest und einzelne States publishst die nicht von Adaptern stammen - ist nichts angehakt.

                          lakelounge 1 Reply Last reply Reply Quote 1
                          • lakelounge
                            lakelounge @mickym last edited by

                            @mickym Wow! Herzlichen Dank für deine mega-ausführliche Antwort! Ich habe verstanden, um was es geht und werd das asap umsetzen.

                            Meine Lösung wäre jetzt so gewesen:

                            Bildschirmfoto 2022-09-01 um 22.11.46.png

                            abonniert ist nur home/# - darauf senden alle Geräte, von denen ich Werte im ioBroker möchte
                            published wird vom ioBroker nur unter lakelounge-

                            Aber ich arbeite noch in Ruhe deine Anleitung durch 😉

                            Danke nochmal und schönen Abend
                            .

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

                              @lakelounge Nei - das Prefix muss immer mit einen / enden und ich empfehle meine Konfig. So was ist gefährlich - das gibt nur ewig lange Strings - die Topics müssen immer mit dem Trenner / - sonst gibts keine Hierarchien. 😉

                              lakelounge 2 Replies Last reply Reply Quote 1
                              • lakelounge
                                lakelounge @mickym last edited by

                                @mickym Verstehe! Und, Asche auf mein Haupt, dass ich den mqtt-Adapter verdächtigt habe! Hab einen Slash ans Ende gemacht … Deine Lösung mach ich die Tage … Man muss ja leider immer nebenbei auch noch was arbeiten 🙂

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

                                  @mickym hach … die Load ist wieder bei 0.14 … was ein Glück! 🙂

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

                                    So, moin. Hab gerade mal alles gelesen ... und alles ist gesagt dank @mickym

                                    1 Reply Last reply Reply Quote 2
                                    • SRo769
                                      SRo769 last edited by SRo769

                                      Hallo zusammen. Also ich habe seit 3 Tagen nach Update auf Adapter-Version 4.07 (MQTT Broker/Client) das gleiche Problem.
                                      Konfiguration:
                                      1x Raspberry-Pi (Dietpi) mit Node-Red und MQTT-Server
                                      2x IOBroker auf 2 unterschiedlichen Proxmox-Systemen (Adapter im Client-Modus) (Proxmox-Systeme 2x Intel-NUC)

                                      Konfiguration lief seit ca. 2 Jahren ohne Probleme. Seit 3 Tagen steigt nun zu unterschiedlichen Zeiten die Gesamtbelastung beider Proxmox-System bis Anschlag an und geht von allein nicht mehr runter. Das Stoppen und erneute Starten der beiden Adapter in den IOBrokern beendet den "Spuk" und alles ist wieder normal. Auf beiden System sind zusätzliche MQTT-Adapter sowohl im Server- als auch im Clientmodus aktiv. Diese verursachen die Belastung nicht.
                                      Den Raspberry-Pi und seine Systeme sind bereits neugestartet und auf aktuellem Software-Stand.
                                      Ich werde jetzt einen der beiden Server mal auf die biss dato laufende Version des MQTT-Adapters downgraden. Vielleicht hilft das ja erstmal.

                                      Bin für weitere Ideen/Vorschläge sehr dankbar.

                                      Homoran 1 Reply Last reply Reply Quote 0
                                      • Homoran
                                        Homoran Global Moderator Administrators @SRo769 last edited by

                                        @sro769 sagte in mqtt Adapter 4.0.7 Hohe CPU Load:

                                        Bin für weitere Ideen/Vorschläge sehr dankbar.

                                        Hast du die Konfiguration verglichen mit dem was hier besprochen wurde?

                                        SRo769 1 Reply Last reply Reply Quote 0
                                        • SRo769
                                          SRo769 @Homoran last edited by

                                          @homoran beide Adapter sind schon immer so eingestellt gewesen. Auf Server 1 empfängt der Adapter nur ohne etwas zu senden. Auf Server 2 sendet der Adapter nur etwas und empfängt nix. Zwischen Server1 und Server2 gibt es keine gemeinsame Daten. Beide Server hängen eben nur an dem einen MQTT-Server.

                                          lakelounge BananaJoe 2 Replies Last reply Reply Quote 0
                                          • lakelounge
                                            lakelounge @SRo769 last edited by lakelounge

                                            @sro769 schau mal mit MQTT-Explorer, in dem du dir alles (/#) anzeigen lässt, ob, so wie bei mir, bei einem Device Tausende von Meldungen auflaufen. Bei mir war es wohl ein verwaister Datenpunkt. Seit ich den gelöscht und die Dinge nach der Anleitung von @mickym umgestellt habe, läuft alles wieder.

                                            So sah das aus (nach wenigen Sekunden - siehe stat, 47.615 Meldungen). Nach einer Minuten waren über 200.000 Meldungen aufgelaufen.
                                            delock.png

                                            Der Datenpunkt war von einem Testscript, das aber nicht gelaufen ist. Also nur ein „rumliegender“ Datenpunkt ohne Sinn und Nutzen …

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            872
                                            Online

                                            31.7k
                                            Users

                                            79.9k
                                            Topics

                                            1.3m
                                            Posts

                                            7
                                            54
                                            2955
                                            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