Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Tester
    4. Test Adapter e3dc-rscp v0.0.x GitHub

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Test Adapter e3dc-rscp v0.0.x GitHub

    This topic has been deleted. Only users with topic management privileges can see it.
    • M
      Matis @ArnoD last edited by

      @arnod Ich hab auf meiner Synology die CPU Probleme nicht, aber ich hab auch nur eine JS Instanz.0. Warum sollte man denn mehrere laufen lassen?

      A 1 Reply Last reply Reply Quote 0
      • E
        ecki945 @ecki945 last edited by

        Der Adapter ist ja der Hammer. Großes Lob am den Entwickler @ujok

        1 Reply Last reply Reply Quote 0
        • A
          ArnoD @Thomas Braun last edited by ArnoD

          @thomas-braun
          Die drei Instanzen sind nicht das Problem, auch wenn nur eine Installiert ist bleibt das Problem dasselbe, habe es nur mit einer dritten ohne Scripte getestet um sicher zu sein das die Scripte keinen Einfluss haben. ( javascript.0 und javascript.1 waren während dem Test gestoppt)
          Ich habe immer zwei Instanzen vom Javascript Adapter, da ich eine zum Testen oder erstellen von neuen Scripten verwende.

          1 Reply Last reply Reply Quote 0
          • A
            ArnoD @Matis last edited by

            @matis
            Da bei dir der ioBroker nicht einfriert, wenn du den Adapter e3dc.rscp mit dem Abfrageintervall kurz auf 1 s laufen lässt,
            könntest du mal den Adapter e3dc.rscp stoppen und dann dir diese beiden Werte ansehen:
            system.adapter.javascript.0.inputCount
            system.adapter.javascript.0.outputCount

            Danach auch den Adapter e3dc.rscp starten um zu sehen wie weit diese Werte ansteigen:
            system.adapter.javascript.0.inputCount
            system.adapter.javascript.0.outputCount
            system.adapter.e3dc-rscp.0.inputCount
            system.adapter.e3dc-rscp.0.outputCount

            Würde mich mal interessieren wie weit sich das bei dir aufschaukelt.

            M 1 Reply Last reply Reply Quote 0
            • M
              Matis last edited by

              @arnod

              CPU-IoBroker: 9,5% bei 30 sek.
              8,8% bei e3dc-rscp off
              23,5% bei 1 sek.

              ed3dc-rscp off:
              system.adapter.javascript.0.inputCount: 1000/15sek
              system.adapter.javascript.0.outputCount: 400/15sek

              e3dc.rscp 1 sek:
              system.adapter.javascript.0.inputCount: 4000/15sek
              system.adapter.javascript.0.outputCount: 300/15sek
              system.adapter.e3dc-rscp.0.inputCount: 66/15sek
              system.adapter.e3dc-rscp.0.outputCount: 6325/15sek

              Mit einer Sekunde läuft zwar alles noch, doch teilweise brauchen die iobroker-Seiten lange für den Aufbau.
              Nach ca. 5 Minuten (so lange hatte ich bisher nie gewartet) waren keine VIS-Anzeigen-Updates mehr möglich. Iobroker lief aber noch.
              Die Instanz konnte ich nicht mehr per GUI anhalten.
              Kill e3dc-rscp.0 hat funktioniert. Danach lief Iobroker auch wieder gut erreichbar und ich konnte mit 30sek. wieder die Instanz starten.

              1 Reply Last reply Reply Quote 0
              • M
                Matis @ArnoD last edited by

                @arnod
                mit 5 sek läuft noch alles sehr stabil und bedienbar:

                system.adapter.javascript.0.inputCount: 2400/15sek
                system.adapter.javascript.0.outputCount: 480/15sek
                system.adapter.e3dc-rscp.0.inputCount: 24/15sek
                system.adapter.e3dc-rscp.0.outputCount: 2003/15sek

                A 1 Reply Last reply Reply Quote 0
                • A
                  ArnoD @Matis last edited by

                  @matis

                  ok danke, wie sind die Werte vom der Javascript.0 Instanz ohne e3dc-rscp Instanz ?
                  Vermute mal wesentlich niedriger.
                  Was passiert wenn du 1 sek. einstellst?

                  M 1 Reply Last reply Reply Quote 0
                  • M
                    Matis @ArnoD last edited by

                    @arnod Siehe eins weiter oben!

                    A 1 Reply Last reply Reply Quote 0
                    • A
                      ArnoD @Matis last edited by

                      @matis ok Danke, hatte ich überlesen 🙂
                      Das bedeutet das du mit 1 sek. auch Probleme hast.

                      @ujok
                      Man könnte mal versuchen nur die wichtigsten Werte im 1 sek. Takt abzufragen wie
                      TAG_EMS_REQ_POWER_PV
                      TAG_EMS_REQ_POWER_BAT
                      TAG_EMS_REQ_POWER_HOME
                      TAG_EMS_REQ_POWER_GRID
                      TAG_EMS_REQ_POWER_ADD

                      und den Rest alle 10 sek.

                      1 Reply Last reply Reply Quote 0
                      • A
                        ArnoD last edited by

                        Ich habe jetzt mal versucht wie viele Werte mit 1 sek. Abgerufen werden können ohne das man ein Problem mit der CPU Auslastung bekommt.
                        Mit 11 Werten ist es noch im grünen Bereich bei unter 40% und nur ein paar spitzen bis 88%.
                        Ich habe diese Werte mit "RefreshPeriod": "short" eingestellt:
                        REQ_POWER_BAT
                        REQ_POWER_HOME
                        REQ_POWER_GRID
                        REQ_POWER_ADD
                        REQ_MODE (kann man diskutieren, ob man diesen Wert wirklich live benötigt)
                        REQ_STATUS
                        REQ_ALIVE
                        REQ_STATE
                        REQ_AC_POWER
                        REQ_AC_VOLTAGE
                        REQ_AC_CURRENT

                        Mit diesen Werten sieht die CPU Auslastung auch über einen längeren Zeitraum auf der Synology so aus:
                        auslastung.png

                        M 1 Reply Last reply Reply Quote 0
                        • M
                          Matis @ArnoD last edited by

                          @arnod
                          @ujok

                          Woran kann ich denn nun sehen, welcher Wert kurz, mittel, lang ist?
                          Ich finde es gut, dass es drei Abstufungen gibt.
                          Die 12 kurzen sind auch alle auf modbus und man bekommte die dort einfach auch im 1 Sek. Takt.
                          Dafür hätte ich gerne andere vielleicht nicht nur in Minuten oder gar Stunden.

                          Ich fände es besser, wenn man selbst entscheiden kann, wie lang die Stufen sind,
                          d.h. alle drei in Stufen in Sekunden und man kann selbst einstellen.
                          Mal 60 o. 3600 bekommt man sicher noch hin 🙂

                          1 Reply Last reply Reply Quote 0
                          • git-kick
                            git-kick Developer last edited by

                            @arnod

                            Danke für die Last-Analyse! Ich habe das eingebaut: mit dem "kurzen" Intervall werden jetzt nur noch die genannten elf Felder abgefragt. Damit pendelt sich die CPU-Last der ioBroker-Instanz auf meinem Entwicklungs-Notebook (i7-1065G7) bei ca. 1,5% ein, wenn ich "Abfrageintervall kurz" = 1 sec setze.

                            Zusätzlich kann man jetzt ganze Namespaces nach Bedarf ausblenden.

                            https://github.com/git-kick/ioBroker.e3dc-rscp/tree/v0.0.12-beta

                            0.0.12-beta

                            • New in configuration panel: select namespaces to query - use it to reduce CPU load (and transmitted data volume)
                            • Polling interval: only 11 most important parameters left in "short" class, according to @ArnoD's analysis
                            1 Reply Last reply Reply Quote 0
                            • A
                              ArnoD last edited by

                              @ujok sagte in Test Adapter e3dc-rscp v0.0.x GitHub:

                              0.0.12-beta

                              👍 Werde ich gleich mal testen 🙂

                              1 Reply Last reply Reply Quote 0
                              • A
                                ArnoD last edited by

                                @matis sagte in Test Adapter e3dc-rscp v0.0.x GitHub:

                                Woran kann ich denn nun sehen, welcher Wert kurz, mittel, lang ist?
                                Ich finde es gut, dass es drei Abstufungen gibt.
                                Die 12 kurzen sind auch alle auf modbus und man bekommte die dort einfach auch im 1 Sek. Takt.

                                Sehen kann man es nur im Adapterverzeichnis, indem man sich die RscpTags.json ansieht.
                                Die Frage, ob man sich diese Werte über Modbus holt, habe ich mir auch schon gestellt, andererseits hat es natürlich auch einen Charme alles mit einem Adapter hinzubekommen und sich die Ressourcen für den zweiten Adapter zu sparen. Kann aber sein, dass man noch darauf zurückgreifen muss, wenn jetzt noch weitere Werte dazukommen.
                                Ich denke, man muss sich nur gut überlegen, was man wirklich als live Ansicht benötigt. Alle Werte wo ich nicht mit einer Steuerung sofort darauf reagieren will, muss ich auch nicht jede sek. Aktualisieren. Träge Werte wie Temperaturen sicher auch nicht.
                                Das gute ist erstmal das alles so weit funktioniert und man es sich nach Belieben einstellen kann.
                                Übrigens, die Zeiten können auch als 0.5 für 30 sek. im Minutenfeld eingegeben werden. 😉

                                M 1 Reply Last reply Reply Quote 0
                                • M
                                  Matis @ArnoD last edited by Matis

                                  @arnod sagte in Test Adapter e3dc-rscp v0.0.x GitHub:

                                  Übrigens, die Zeiten können auch als 0.5 für 30 sek. im Minutenfeld eingegeben werden.

                                  Prima, ich hab mal wieder den Fehler gemacht und es mit Komma versucht 🙂

                                  Sehr cool, die 0.0.12!

                                  1 Reply Last reply Reply Quote 0
                                  • A
                                    ArnoD last edited by

                                    Uli 0.0.12 läuft ohne Fehler 👍

                                    Vielleicht eine optische Verbesserung für eine Anzeige in VIS.
                                    Wenn man eine Namespace abwählt, sollten die Werte auch gelöscht werden, da sonst die Anzeigen beim alten Wert hängen bleiben und man in Vis eventuell nicht mitbekommt, dass es alte eingefrorene Werte sind.
                                    Aber wie gesagt nur eine reine optische Korrektur.

                                    git-kick 1 Reply Last reply Reply Quote 0
                                    • git-kick
                                      git-kick Developer @ArnoD last edited by

                                      @arnod said in Test Adapter e3dc-rscp v0.0.x GitHub:

                                      Vielleicht eine optische Verbesserung für eine Anzeige in VIS.
                                      Wenn man eine Namespace abwählt, sollten die Werte auch gelöscht werden, da sonst die Anzeigen beim alten Wert hängen bleiben und man in Vis eventuell nicht mitbekommt, dass es alte eingefrorene Werte sind.

                                      Ja, es wäre kein Problem, den jeweiligen Hauptast im Objektbaum zu löschen. Aber dann verschwinden alle Werte, auch z.B. Modellnamen, die sich nie ändern. Ich dachte vielleicht ist es ganz praktisch, die Werte einmal einzuslesen und dann die Aktualisierung zu stoppen. Aber ich stimme auch zu, dass (nicht erkennbar) veraltete Werte unschön sind.
                                      Nicht so einfach ist es, die Werte "zurückzusetzen": erstens müsste ich dann die Werte einzeln anfassen, zweitens ist nicht immer eindeutig, was der "nicht-definiert-Wert" eigentlich ist, womöglich abhängig vom Update-Intervall (short/medium/long). Kurz: das wäre mir zu viel Aufwand/Komplexität für den (nur optischen) Effekt.

                                      Gibt es noch Wortmeldungen zu der Frage:
                                      Wenn man einen Namespace abschaltet,
                                      A) alles so einfrieren wie es ist oder
                                      B) den Objekt-Teilbaum komplett löschen
                                      ??

                                      M 1 Reply Last reply Reply Quote 0
                                      • git-kick
                                        git-kick Developer @git-kick last edited by git-kick

                                        @arnod said in Test Adapter e3dc-rscp v0.0.x GitHub:

                                        Nachtrag:
                                        Komisch ist die Rückmeldung von e3dc-rscp.0.EMS.MODE.
                                        Wenn SET_POWER_MODE = 0 ist MODE = 0
                                        Wenn SET_POWER_MODE = 1 ist MODE = 0
                                        Wenn SET_POWER_MODE = 2 ist MODE = 1
                                        Wenn SET_POWER_MODE = 3 ist MODE = 2
                                        Wenn SET_POWER_MODE = 4 ist MODE = 2

                                        Hier stimmt noch was nicht.

                                        Ich habe mir dazu nochmal die Tag-Liste angesehen: die Werte für MODE sind dort nicht definiert - ich hatte einfach angenommen, dass sie denen von SET_POWER_MODE entsprechen. Diese Annahme war offenbar falsch.

                                        Wäre es also sinnvoll MODE so zu übersetzen?
                                        0 = IDLE
                                        1 = DISCHARGE
                                        2 = CHARGE

                                        (Allerdings wäre mir dann immer noch nicht klar, was sie SET_POWER_MODE Werte genau bedeuten, speziell die Unterschiede NORMAL/IDLE und CHARGE/GRID_CHARGE).

                                        A 1 Reply Last reply Reply Quote 0
                                        • M
                                          Matis @git-kick last edited by

                                          @ujok sagte in Test Adapter e3dc-rscp v0.0.x GitHub:

                                          Gibt es noch Wortmeldungen zu der Frage:
                                          Wenn man einen Namespace abschaltet,
                                          A) alles so einfrieren wie es ist oder
                                          B) den Objekt-Teilbaum komplett löschen
                                          ??

                                          Bitte NICHT löschen "N/A" ist noch viel schlechter als ein alter Wert.
                                          Alte Werte kann jeder selber abfangen, das machen andere Adapter auch nicht.

                                          1 Reply Last reply Reply Quote 0
                                          • git-kick
                                            git-kick Developer last edited by

                                            @matis said in Test Adapter e3dc-rscp v0.0.x GitHub:

                                            Bitte NICHT löschen "N/A" ist noch viel schlechter als ein alter Wert.
                                            Alte Werte kann jeder selber abfangen, das machen andere Adapter auch nicht.

                                            Guter Hinweis! Bei der Darstellung kann man bei Bedarf prüfen, ob ein Wert noch aktualisiert wird oder "eingefroren" ist. Hier als Beispiel der Check, ob der BAT-Namespace abgefragt wird:

                                            console.log(getObject('system.adapter.e3dc-rscp.0').native.query_bat)
                                            
                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            537
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            battery e3dc electricity energy photovoltaic rscp
                                            38
                                            470
                                            73681
                                            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