Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Node-Red
  5. [HowTo] Huawei SUN2000 WR Modbus mit node-red (read + write)

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.3k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.0k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    15
    1
    2.4k

[HowTo] Huawei SUN2000 WR Modbus mit node-red (read + write)

Geplant Angeheftet Gesperrt Verschoben Node-Red
574 Beiträge 110 Kommentatoren 223.6k Aufrufe 108 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • S stoffel67

    Warum werden einige der Werte nicht angelegt/ausgegeben?
    5CB5D16E-5871-4048-A28E-64DEEDA089FF.jpeg

    M Offline
    M Offline
    madmat17
    schrieb am zuletzt editiert von madmat17
    #183

    @stoffel67
    Es sieht so aus, als wären die Nodes bei dir inaktiv. Doppklick darauf -> Register "Setup" -> ganz links unten von Disabled auf Enabled umstellen und neu deployen.

    Frage in die Runde:
    Seit wenigen Tagen bekomme ich keinen Wert mehr aus den Registern 37015 (Battery - current day charge capacity) und 37017 (Battery - current day discharge capacity). Hat jeman ähnliches beobachtet? Früher bekam ich dort immer sauber die Werte...
    Alle anderen Register geben die Werte wie gewohnt aus.
    Dongle läuft auf FW Version V100R001C00SPC130
    Inverter (SUN2000-6KTL-M1) läuft auf FW Version V100R001C00SPC150

    Lösung gefunden: Die Register 37015 & 37017 sind jene, mit denen die Werte der einzelnen Akku-Module ("Engery Storage Unit") ausgelesen werden. Scheinbar sind diese plötzlich maskiert (wenngleich ich kürzlich kein FW-Update vorgenommen hatte - aber evtl. war das auch ein forced update) und werden über den TCP-MODBUS nicht mehr ausgegeben.
    In den JSONs weiter oben werden ebenfalls diese Register abgefragt (war dann OK, solange man nur einen Akku hatte - inzwischen wie gesagt nicht mehr zu gebrauchen).
    Lösung: Auf jene Register ausweichen, welche die Werte aller Akkumodule zusammenfassen. Auf der HUAWEI-Seite habe ich gerade die vollständige MODBUS Interface Definition nicht gefunden, kann man aber hier nachschlagen (Version 04 vom 29.03.2022 - direkter Link). Die Abfrage über die dort angegebenen Register 37784 und 37786 funktioniert klaglos.

    LG,
    Mat

    S 1 Antwort Letzte Antwort
    1
    • A A1uca2d

      @fridolin01 @badsnoopy667
      Ich glaube mittlerweile, dass es an der Anzahl der Abfragen lag.

      Habe bei meinen ModBus Getter mal in den Optionen "Show Errors" angeschaltet.
      dba00d7a-078c-49f6-aa8e-7c6091d528a2-image.png

      Da habe ich die Meldung erhalten, dass der Controller zu viele anfragen bearbeiten musste.
      Ich habe das Abfrageintervall nun auf 18Sek gesetzt.
      a3f62468-597b-422e-91a5-5ae44d484d83-image.png

      Und hier mein überarbeiteter kompletter Flow:


      flows.json

      Hat vielleicht jemand eine Idee, warum mein Dongle mit der "hohen" Abfragerate ein Problem hat und die anderen Teilnehmer im Forum wohl eher nicht?

      M Offline
      M Offline
      madmat17
      schrieb am zuletzt editiert von
      #184

      @a1uca2d

      Das Thema mit den Abfragen kannst du auch anders umschiffen.
      Du kannst mehrere Register auf einmal abfragen (ich habe zB in 2 Abfragen alles drinnen - da ein recht großer Adressbereich für mich nicht so interessant ist):

      • Register 32000-32116:
        cf21b6ea-6e0d-422f-a361-79df4952364e-image.png
        Die Abfrage triggert dann die zweite Abfrage
        edd8206a-900b-4843-b7c4-87fec141bf81-image.png

      • Register 37000-37125:
        6fda4d92-475f-4c9c-b144-a09d33432e6c-image.png

      Die Daten laufen dann durch einen edit puffer-parser node, werden in einem join-node zusammengefügt und (in meinem Fall) auf einmal in eine InfluxDB geschrieben:
      2f3e0ad6-6c9f-458e-bc19-7af60b771b51-image.png

      Nur als Anregung bzw. Idee, wenn man den Overhead der Register-Anfragen reduzieren möchte. ;-)

      Gruß,
      Mat

      B W Christof LewandowskiC 3 Antworten Letzte Antwort
      0
      • M madmat17

        @a1uca2d

        Das Thema mit den Abfragen kannst du auch anders umschiffen.
        Du kannst mehrere Register auf einmal abfragen (ich habe zB in 2 Abfragen alles drinnen - da ein recht großer Adressbereich für mich nicht so interessant ist):

        • Register 32000-32116:
          cf21b6ea-6e0d-422f-a361-79df4952364e-image.png
          Die Abfrage triggert dann die zweite Abfrage
          edd8206a-900b-4843-b7c4-87fec141bf81-image.png

        • Register 37000-37125:
          6fda4d92-475f-4c9c-b144-a09d33432e6c-image.png

        Die Daten laufen dann durch einen edit puffer-parser node, werden in einem join-node zusammengefügt und (in meinem Fall) auf einmal in eine InfluxDB geschrieben:
        2f3e0ad6-6c9f-458e-bc19-7af60b771b51-image.png

        Nur als Anregung bzw. Idee, wenn man den Overhead der Register-Anfragen reduzieren möchte. ;-)

        Gruß,
        Mat

        B Offline
        B Offline
        badsnoopy667
        schrieb am zuletzt editiert von
        #185

        @madmat17
        Das klingt spannend. Kannst du deinen Flow Mal Posten? Danke Dir!

        M 1 Antwort Letzte Antwort
        0
        • M madmat17

          @stoffel67
          Es sieht so aus, als wären die Nodes bei dir inaktiv. Doppklick darauf -> Register "Setup" -> ganz links unten von Disabled auf Enabled umstellen und neu deployen.

          Frage in die Runde:
          Seit wenigen Tagen bekomme ich keinen Wert mehr aus den Registern 37015 (Battery - current day charge capacity) und 37017 (Battery - current day discharge capacity). Hat jeman ähnliches beobachtet? Früher bekam ich dort immer sauber die Werte...
          Alle anderen Register geben die Werte wie gewohnt aus.
          Dongle läuft auf FW Version V100R001C00SPC130
          Inverter (SUN2000-6KTL-M1) läuft auf FW Version V100R001C00SPC150

          Lösung gefunden: Die Register 37015 & 37017 sind jene, mit denen die Werte der einzelnen Akku-Module ("Engery Storage Unit") ausgelesen werden. Scheinbar sind diese plötzlich maskiert (wenngleich ich kürzlich kein FW-Update vorgenommen hatte - aber evtl. war das auch ein forced update) und werden über den TCP-MODBUS nicht mehr ausgegeben.
          In den JSONs weiter oben werden ebenfalls diese Register abgefragt (war dann OK, solange man nur einen Akku hatte - inzwischen wie gesagt nicht mehr zu gebrauchen).
          Lösung: Auf jene Register ausweichen, welche die Werte aller Akkumodule zusammenfassen. Auf der HUAWEI-Seite habe ich gerade die vollständige MODBUS Interface Definition nicht gefunden, kann man aber hier nachschlagen (Version 04 vom 29.03.2022 - direkter Link). Die Abfrage über die dort angegebenen Register 37784 und 37786 funktioniert klaglos.

          LG,
          Mat

          S Offline
          S Offline
          stoffel67
          schrieb am zuletzt editiert von
          #186

          @madmat17 said in [HowTo] Huawei SUN2000 WR Modbus mit node-red (read + write):

          Es sieht so aus, als wären die Nodes bei dir inaktiv. Doppklick darauf -> Register "Setup" -> ganz links unten von Disabled auf Enabled umstellen und neu deployen.

          Danke für den Hinweis... das wars:+1:

          Mein Adapter: JUNG/GIRA eNet-Adapter

          S 1 Antwort Letzte Antwort
          0
          • A Offline
            A Offline
            abrodeck
            schrieb am zuletzt editiert von
            #187

            Hallo @badsnoopy667 und alle anderen welche folgende Frage beantworten können.

            Dank der guten Vorarbeit hier habe ich jetzt auch Node Red soweit, dass ich sinnvolle Daten aus meinem SUN2000-6KTL-M1 und auch aus dem Dongle in den ioBroker bekomme. Ich stehe allerdings völlig auf dem Schlauch, wenn es darum geht, die Daten so zu verarbeiten und zu speichern, dass ich später eine Historie habe, also z.B eine Anzeige der Solarproduktion, des Verbrauchs oder der Einspeisung der letzen Tage, Wochen, Monate ... Ich habe auf verschiedenen Grafana-Screenshots hier so etwas schon gesehen, allerdings fehlt mir einfach der Ansatz, es umzusetzen. Ich schreibe momentan bestimmte Werte mit dem SQL-Adapter weg und versuche dann Grafen mit FLOT zu bauen, komme da aber nicht wirklich weiter. Ich hoffe, es einigermaßen verständlich ausgedrückt zu haben und würde mich über jeden Ansatz freuen. Vielen Dank.

            Gruß Andreas

            B 1 Antwort Letzte Antwort
            0
            • S stoffel67

              @madmat17 said in [HowTo] Huawei SUN2000 WR Modbus mit node-red (read + write):

              Es sieht so aus, als wären die Nodes bei dir inaktiv. Doppklick darauf -> Register "Setup" -> ganz links unten von Disabled auf Enabled umstellen und neu deployen.

              Danke für den Hinweis... das wars:+1:

              S Offline
              S Offline
              stoffel67
              schrieb am zuletzt editiert von
              #188

              Können die beiden Werte für Startup und Shutdown auch ausgelesen werden?
              Ich hab es mit 32091 und 32093 versucht, ich bekomme aber z.B. permanent „512“ zuzrück?

              Mein Adapter: JUNG/GIRA eNet-Adapter

              1 Antwort Letzte Antwort
              0
              • J joschipp

                Ich hab für meine Anwendung eine schnelle Abfrage einiger Register benötigt, und die restlichen werden seltener benötigt. Das hab ich jetzt folgendermaßen realisiert (basierend auf Vorschlägen weiter oben - vielen Dank dafür):
                01.PNG

                Count 3 ist ein Zähler, der 3 Ausgänge durchtaktet, der 1. Ausgang triggert die Abfrage vom Meter.Active_Power, den Wert will ich häufig aktualisiert haben. Sobald die Daten empfangen wurden, geht die Meldung über den Link zurück an die Trigger - Funktion. Die triggert den Count 3, und der zählt weiter auf den 2. Ausgang und triggert die Abfrage vom Inverter.Active_Power (brauch ich auch häufig).
                Der 3. Ausgang triggert dann einen Zähler mit 25 Ausgängen:
                02.PNG
                Hier wird die Abfrage der restlichen 25 Register, die ich nicht häufig brauche, getriggert.
                Die Trigger Funktion hat auch noch eine Timeout - Überprüfung, wenn mal keine Antwort kommen sollte, dann wird nach 5 Sekunden getriggert.
                Damit werden jetzt die beiden wichtigen Register alle 1-2 Sekunden aktualisiert und der Rest langsamer.
                Mit dieser Lösung hab ich sicher gestellt, das eine Abfrage erst bzw. sofort nach dem Empfang der vorigen Abfrage erfolgt, somit hat man die max. Geschwindigkeit und keinen Datenverlust.

                flows.json

                PS: das Problem mit den fehlenden Datenpunkten und das manuelle Anlegen (siehe weiter oben) kann man sich sparen, wenn man in der Node-Red Instanz "Erstellung von Fremd-Objekten" zulässt
                03.PNG

                mfg

                T Offline
                T Offline
                ts_482
                schrieb am zuletzt editiert von
                #189

                @joschipp said in [HowTo] Huawei SUN2000 WR Modbus mit node-red (read + write):

                Ich hab für meine Anwendung eine schnelle Abfrage einiger Register benötigt, und die restlichen werden seltener benötigt. Das hab ich jetzt folgendermaßen realisiert (basierend auf Vorschlägen weiter oben - vielen Dank dafür):
                01.PNG

                Count 3 ist ein Zähler, der 3 Ausgänge durchtaktet, der 1. Ausgang triggert die Abfrage vom Meter.Active_Power, den Wert will ich häufig aktualisiert haben. Sobald die Daten empfangen wurden, geht die Meldung über den Link zurück an die Trigger - Funktion. Die triggert den Count 3, und der zählt weiter auf den 2. Ausgang und triggert die Abfrage vom Inverter.Active_Power (brauch ich auch häufig).
                Der 3. Ausgang triggert dann einen Zähler mit 25 Ausgängen:
                02.PNG
                Hier wird die Abfrage der restlichen 25 Register, die ich nicht häufig brauche, getriggert.
                Die Trigger Funktion hat auch noch eine Timeout - Überprüfung, wenn mal keine Antwort kommen sollte, dann wird nach 5 Sekunden getriggert.
                Damit werden jetzt die beiden wichtigen Register alle 1-2 Sekunden aktualisiert und der Rest langsamer.
                Mit dieser Lösung hab ich sicher gestellt, das eine Abfrage erst bzw. sofort nach dem Empfang der vorigen Abfrage erfolgt, somit hat man die max. Geschwindigkeit und keinen Datenverlust.

                flows.json

                PS: das Problem mit den fehlenden Datenpunkten und das manuelle Anlegen (siehe weiter oben) kann man sich sparen, wenn man in der Node-Red Instanz "Erstellung von Fremd-Objekten" zulässt
                03.PNG

                mfg

                S 1 Antwort Letzte Antwort
                0
                • A abrodeck

                  Hallo @badsnoopy667 und alle anderen welche folgende Frage beantworten können.

                  Dank der guten Vorarbeit hier habe ich jetzt auch Node Red soweit, dass ich sinnvolle Daten aus meinem SUN2000-6KTL-M1 und auch aus dem Dongle in den ioBroker bekomme. Ich stehe allerdings völlig auf dem Schlauch, wenn es darum geht, die Daten so zu verarbeiten und zu speichern, dass ich später eine Historie habe, also z.B eine Anzeige der Solarproduktion, des Verbrauchs oder der Einspeisung der letzen Tage, Wochen, Monate ... Ich habe auf verschiedenen Grafana-Screenshots hier so etwas schon gesehen, allerdings fehlt mir einfach der Ansatz, es umzusetzen. Ich schreibe momentan bestimmte Werte mit dem SQL-Adapter weg und versuche dann Grafen mit FLOT zu bauen, komme da aber nicht wirklich weiter. Ich hoffe, es einigermaßen verständlich ausgedrückt zu haben und würde mich über jeden Ansatz freuen. Vielen Dank.

                  Gruß Andreas

                  B Offline
                  B Offline
                  badsnoopy667
                  schrieb am zuletzt editiert von
                  #190

                  @abrodeck
                  Ich speichere die Werte für Erzeugung, Verbrauch etc. mit dem History Adapter und nutze dann ebenfalls FLOT zur Darstellung. Den SQL-Adapter kenne ich nicht.
                  Die ganzen Werte wie Monatsertrag, Jahresertrag usw. habe ich nicht in iobroker umgesetzt, da gucke ich einfach in die FusionSolar App wenn ich das wissen will.
                  Das sollte sich aber auch irgendwie mit dem Sourcenanalytix Adapter umsetzen lassen. Aber mit dem stehe ich auf Kriegsfuß. Ich verstehe das Teil einfach nicht. ;)

                  1 Antwort Letzte Antwort
                  0
                  • W warp-it

                    @joeysch said in [HowTo] Huawei SUN2000 WR Modbus mit node-red (read + write):

                    Kann es sein, das die IP-Adresse die in der Wlan-Fe angegeben ist bei dir von einem Gerät belegt ist und er dahin connected?

                    Nö, die in WLAN-FE eingetragene IP-Adresse existiert in meinem LAN nicht.

                    J Offline
                    J Offline
                    Joogibaer
                    schrieb am zuletzt editiert von
                    #191

                    @warp-it

                    hast du hier den Grund gefunden? ich habe gerade das selbe "PRoblem" und noch keine Werte

                    1 Antwort Letzte Antwort
                    0
                    • T ts_482

                      @joschipp said in [HowTo] Huawei SUN2000 WR Modbus mit node-red (read + write):

                      Ich hab für meine Anwendung eine schnelle Abfrage einiger Register benötigt, und die restlichen werden seltener benötigt. Das hab ich jetzt folgendermaßen realisiert (basierend auf Vorschlägen weiter oben - vielen Dank dafür):
                      01.PNG

                      Count 3 ist ein Zähler, der 3 Ausgänge durchtaktet, der 1. Ausgang triggert die Abfrage vom Meter.Active_Power, den Wert will ich häufig aktualisiert haben. Sobald die Daten empfangen wurden, geht die Meldung über den Link zurück an die Trigger - Funktion. Die triggert den Count 3, und der zählt weiter auf den 2. Ausgang und triggert die Abfrage vom Inverter.Active_Power (brauch ich auch häufig).
                      Der 3. Ausgang triggert dann einen Zähler mit 25 Ausgängen:
                      02.PNG
                      Hier wird die Abfrage der restlichen 25 Register, die ich nicht häufig brauche, getriggert.
                      Die Trigger Funktion hat auch noch eine Timeout - Überprüfung, wenn mal keine Antwort kommen sollte, dann wird nach 5 Sekunden getriggert.
                      Damit werden jetzt die beiden wichtigen Register alle 1-2 Sekunden aktualisiert und der Rest langsamer.
                      Mit dieser Lösung hab ich sicher gestellt, das eine Abfrage erst bzw. sofort nach dem Empfang der vorigen Abfrage erfolgt, somit hat man die max. Geschwindigkeit und keinen Datenverlust.

                      flows.json

                      PS: das Problem mit den fehlenden Datenpunkten und das manuelle Anlegen (siehe weiter oben) kann man sich sparen, wenn man in der Node-Red Instanz "Erstellung von Fremd-Objekten" zulässt
                      03.PNG

                      mfg

                      S Offline
                      S Offline
                      stoffel67
                      schrieb am zuletzt editiert von
                      #192

                      @ts_482
                      Hallo,
                      kannst du mal schauen, ob du auch die Register 32091 und 32093 lesen kannst?

                      Mein Adapter: JUNG/GIRA eNet-Adapter

                      1 Antwort Letzte Antwort
                      0
                      • B badsnoopy667

                        @kep42010
                        Hast du die ID in ALLEN Nodes geändert? Nur in der Haupteinstellung reicht nicht.

                        J Offline
                        J Offline
                        Joogibaer
                        schrieb am zuletzt editiert von
                        #193

                        @badsnoopy667

                        was meinst du in jedem Notes? Man gibt die Id doch nur im Modbus Client an, oder?

                        B 1 Antwort Letzte Antwort
                        0
                        • J Joogibaer

                          @badsnoopy667

                          was meinst du in jedem Notes? Man gibt die Id doch nur im Modbus Client an, oder?

                          B Offline
                          B Offline
                          badsnoopy667
                          schrieb am zuletzt editiert von
                          #194

                          @joogibaer
                          Nein, in jedem einzelnen modbus-node steht nochmal die ID drin. die muss überall passen, sonst läuft's nicht. Vielleicht erstmal einen Test-Flow machen der nur ein Register abfragt. Wenn der läuft, dann den ganzen Flow probieren.

                          J 1 Antwort Letzte Antwort
                          0
                          • B badsnoopy667

                            @joogibaer
                            Nein, in jedem einzelnen modbus-node steht nochmal die ID drin. die muss überall passen, sonst läuft's nicht. Vielleicht erstmal einen Test-Flow machen der nur ein Register abfragt. Wenn der läuft, dann den ganzen Flow probieren.

                            J Offline
                            J Offline
                            Joogibaer
                            schrieb am zuletzt editiert von Joogibaer
                            #195

                            @badsnoopy667

                            Guten Morgen, danke jetzt ist alles Grün :)

                            H 1 Antwort Letzte Antwort
                            0
                            • J Joogibaer

                              @badsnoopy667

                              Guten Morgen, danke jetzt ist alles Grün :)

                              H Offline
                              H Offline
                              Hinkebein
                              schrieb am zuletzt editiert von Hinkebein
                              #196

                              Moin,
                              Auf meiner Fuison Solar App habe ich heute ca. 4,9KW erzeugt.
                              Im Modbusregister (32114) steht aber 3.9KW..
                              Da ich aber heute meinen Akku (10KW) von ca. 30% auf 80% Prozent geladen habe, klingen für mich die 5 KW realistischer.
                              Habe ich das falsche Modbusregister erwischt oder hat der 8KT andere Register?

                              update: Lösung gefunden -- Der Wechselrichter hat wirklich nur 3,9 KW produziert .. jetzt frage ich woher die restlichen KWs hergekommen sind um auf 4,9 KW Tagesproduktion zu kommen -- Ich da die Batterie heute 5.5 KW geladen hat und bisher 4.5 KW enthält macht das eine Differenz von 1 KW - dann passt das.. heisst das wohl, das die Ladeleistung der Batterie nicht in der Tagesproduktion eingerechnet wird? -- verwirrendes Tool

                              1 Antwort Letzte Antwort
                              0
                              • M madmat17

                                @a1uca2d

                                Das Thema mit den Abfragen kannst du auch anders umschiffen.
                                Du kannst mehrere Register auf einmal abfragen (ich habe zB in 2 Abfragen alles drinnen - da ein recht großer Adressbereich für mich nicht so interessant ist):

                                • Register 32000-32116:
                                  cf21b6ea-6e0d-422f-a361-79df4952364e-image.png
                                  Die Abfrage triggert dann die zweite Abfrage
                                  edd8206a-900b-4843-b7c4-87fec141bf81-image.png

                                • Register 37000-37125:
                                  6fda4d92-475f-4c9c-b144-a09d33432e6c-image.png

                                Die Daten laufen dann durch einen edit puffer-parser node, werden in einem join-node zusammengefügt und (in meinem Fall) auf einmal in eine InfluxDB geschrieben:
                                2f3e0ad6-6c9f-458e-bc19-7af60b771b51-image.png

                                Nur als Anregung bzw. Idee, wenn man den Overhead der Register-Anfragen reduzieren möchte. ;-)

                                Gruß,
                                Mat

                                W Offline
                                W Offline
                                warp-it
                                schrieb am zuletzt editiert von
                                #197

                                @madmat17

                                Hi Mat,

                                das möchte ich auch versuchen, da auch bei mir mit dem ursprünglichen Flow reichlich Logeinträge entstehen:

                                2023-03-16 16_32_14-logs - IoBroker.jpg

                                Allerdings komme ich mit dem Parsing nicht klar, vielleicht kannst Du da noch mal ein Beispiel oder Screencopy beisteuern. Du schreibst 'edit puffer-parser'. Ist das etwas anderes als der normale 'buffer-parser' den ich in der linken Spalte finde?

                                Viele Grüße
                                Heinrich

                                J 1 Antwort Letzte Antwort
                                0
                                • B badsnoopy667

                                  Achtung: Verbindung mit Modbus Adapter klappt nicht, node-red klappt.

                                  Hier eine Anleitung um den SUN2000 Wechselrichter incl. Batterie und Power Meter per node-red auszulesen und Werte zu schreiben:

                                  1. Wechselrichter korrekt konfigurieren:
                                  Im Wechselrichter muss die Konfiguration per Modbus (TCP) aktiviert sein. Das kann der Installateur direkt erledigen. Alternativ lädt man sich die SUN2000 App auf's Handy und verbindet sich damit über das WLAN des Wechselrichters (also davorstehend im Keller) mit dem WR und stellt das ein. (Unter Kommunikationseinstellungen glaube ich, die Menüs sind ziemlich unübersichtlich mMn.)
                                  Zum Login in die App als Installateur braucht man ein Passwort: 00000a
                                  Eventuell braucht man zum Verbinden auf das WLAN des Wechselrichters auch ein Passwort: Changeme

                                  2. Node-Red installieren und Flow importieren:
                                  Man muss im ioBroker node-red installieren. Außerdem muss man in node-red noch drei zusätzliche NPM Module installieren (geht bei den Instanzeinstellungen):
                                  • node-red-contrib-calc
                                  • node-red-contrib-buffer-parser
                                  • node-red-contrib-modbus

                                  Hat man das erledigt, kann man diesen Flow importieren:

                                  Huawei_SUN2000_node_red_flow_read_write_2023-11.txt

                                  Achtung, weil das hier schon ein paar Mal zu Problemen geführt hat: Man muss die Client-ID in allen Modbus-Nodes korrekt eintragen. Bei mir steht da 2, weil mein Wechselrichter schonmal getauscht wurde. Das muss überall auf den richtigen Wert (meistens 1) geändert werden damit Daten kommen!
                                  Nachdem man den Flow importiert hat muss man ganz rechts im Menü unter "Globale-Konfigurations-Nodes" beim modbus-client noch die IP Adresse vom Wechselrichter und wieder die richtige Client-ID (typischerweise 1) eintragen. (Port ist 502)

                                  3. Hinweise:
                                  Dann sollte die Verbindung eigentlich schon funktionieren. Bei mir war dann noch das Problem, das node-red gemeckert hat, dass die Objekte in iobroker nicht existieren in die er schreiben will.
                                  Um das zu fixen habe ich im Flow alle Output-Nodes (die graublauen Boxen rechts) einmal doppeltgeklickt und dort bei "Auto-create --> Create states if not exist" ausgewählt. Dann kann man noch die Einheit und den Typ festlegen und dann werden die States automatisch beim ersten Lesen angelegt. Hierfür ist es erforderlich, dass in den node-red Instanzeinstellungen noch der Hacken bei "Erstellung von Fremd-Objekten zulassen" aktiviert wird.
                                  Zusätzlich habe ich noch den Wert "Readonly --> Object is writeable" gesetzt. K.a. ob das nötig ist, aber ich hatte den Eindruck, dass die Werte sonst nicht korrekt aktualisiert werden.

                                  Zum Nachlesen gibt es hier noch die Huawei SUN2000 Modbus Register Übersicht:
                                  Solar Inverter Modbus Interface Definitions V5.pdf (Stand 2023)
                                  Im Flow werden die wichtigsten Größen aber schon abgefragt.

                                  4. Modbus-Register schreiben:
                                  Man kann auch Register schreiben! Damit kann man z.B. die Batterie-Entladung auf 0W setzen wenn das eAuto lädt. Damit entlädt sich die Batterie dann nicht unnötig, wenn man das Auto mit Netzstrom lädt im Winter oder Nachts.
                                  Man kann auch TOU (Zeitgesteuertes Laden) aktivieren. Damit kann man wenn man Tibber oder Awattar nutzt zu den günstigen Stunden den Akku aufladen. Um die günstigsten Stunden auszulesen gibt es hier im Forum entsprechende Skripte.

                                  4.1 Zeitgesteuertes Laden korrekt konfigurieren und schreiben:
                                  • AC-Laden muss auf 1 stehen (Register 47087). Kann auch mMn permanent auf 1 bleiben.
                                  • Battery Working Mode (Register 47086) kann zwischen 2 (Maximaler Eigenverbrauch) und 5 (TOU, zeitgesteuert Laden) umgestellt werden.
                                  • Man definiert dann in der Huawei FusionSolar App unter Geräte - Dongle - Parametereinstellungen (die 4 Punkte oben rechts) einfach eine Zeit von 0:00 bis 23:59 jeden Tag "laden" (also den ganzen Tag). Dafür muss die Batterie auf TOU (5) gestellt sein.
                                  • Sobald man jetzt per Modbus das Register 47086 von 2 auf 5 umschaltet, fängt die Batterie aus dem Netz an zu laden.
                                  • Maximaler Ladestrom kann über Register 47075 eingestellt werden.
                                  • Stellt man den Working Mode wieder zurück auf 2, hört das Netzladen auf und die Batterie verhält sich wieder "normal".

                                  Die nötigen ioBroker Datenpunkte muss man noch anlegen. Also zB. Battery_Max_Charge_Power_SET oder Workingmode_Change.

                                  5. Weiteres
                                  5.1 Mehrere Wechselrichter abfragen

                                  Es gibt noch weitere Möglichkeiten den Flow aufzubauen. Man kann mehrere Adressbereiche auf einmal abfragen, das ist ggf. etwas effizienter. Den Flow dazu habe ich aber nicht getestet:

                                  Flow mit Multi-Abfrage

                                  Außerdem enthält der Flow ein Beispiel für die Abfrage mehrerer Wechselrichter in Kaskade. Im Prinzip muss man nur die korrekten IDs pro Wechselrichter eintragen und nicht zu viele Register abfragen, sonst kommen keine Daten mehr. Damit lassen sich auch 3 Wechselrichter (oder ggf. sogar mehr) in einem Flow abfragen.

                                  5.2 Aktuelle Firmware / Modbus Interface Definitions
                                  Hier noch ein Link zu den aktuellen Firmware Versionen:
                                  SUN2000 Firmware

                                  Vielen Dank an alle, die den Input geliefert haben!
                                  Ich hoffe es hilf, wenn ich es hier einmal zusammengefasst habe.

                                  G Offline
                                  G Offline
                                  gerd_r
                                  schrieb am zuletzt editiert von
                                  #198

                                  @badsnoopy667

                                  Hallo,

                                  vielen vielen Dank für diesen sehr umfangreichen und praktikablen Beitrag!

                                  Eine Frage jedoch:
                                  Du verlinkst in deinem Eröffnungsbeitrag auf einen anderen Forenbeitrag in dem man an die PDF für die "Modbus Interface Definitions" kommt.

                                  Das verlinkte PDF scheint jedoch veraltet zu sein.

                                  Jedenfalls nutzt du Register-Addressen, die dort nicht drin vorkommen (bsp. 37066, 37068, usw).

                                  Hast du zufällig eine aktuelle Dokumentation zur Hand und könntest die hier einstellen?

                                  Bei den anderen (älteren) Register klappt es dank deiner Anleitung super!!

                                  Viele Grüße

                                  Gerd

                                  B 1 Antwort Letzte Antwort
                                  0
                                  • G gerd_r

                                    @badsnoopy667

                                    Hallo,

                                    vielen vielen Dank für diesen sehr umfangreichen und praktikablen Beitrag!

                                    Eine Frage jedoch:
                                    Du verlinkst in deinem Eröffnungsbeitrag auf einen anderen Forenbeitrag in dem man an die PDF für die "Modbus Interface Definitions" kommt.

                                    Das verlinkte PDF scheint jedoch veraltet zu sein.

                                    Jedenfalls nutzt du Register-Addressen, die dort nicht drin vorkommen (bsp. 37066, 37068, usw).

                                    Hast du zufällig eine aktuelle Dokumentation zur Hand und könntest die hier einstellen?

                                    Bei den anderen (älteren) Register klappt es dank deiner Anleitung super!!

                                    Viele Grüße

                                    Gerd

                                    B Offline
                                    B Offline
                                    badsnoopy667
                                    schrieb am zuletzt editiert von badsnoopy667
                                    #199

                                    @gerd_r

                                    Modbus interface definitions V4.0
                                    Danke für den Hinweis, habe oben auch die neue Version 4 verlinkt jetzt.

                                    Z 1 Antwort Letzte Antwort
                                    0
                                    • Z Offline
                                      Z Offline
                                      zizu29
                                      schrieb am zuletzt editiert von
                                      #200

                                      @badsnoopy667 Hallo,
                                      ich bekomme beim Importieren immer einen Fehler : SyntaxError: Unexpected token 'c', ..."ert": falsch, "... is not valid JSON

                                      an was kann das liegen, steh total auf dem Schlauch

                                      B 1 Antwort Letzte Antwort
                                      0
                                      • Z zizu29

                                        @badsnoopy667 Hallo,
                                        ich bekomme beim Importieren immer einen Fehler : SyntaxError: Unexpected token 'c', ..."ert": falsch, "... is not valid JSON

                                        an was kann das liegen, steh total auf dem Schlauch

                                        B Offline
                                        B Offline
                                        badsnoopy667
                                        schrieb am zuletzt editiert von badsnoopy667
                                        #201

                                        @zizu29 Du meinst beim Importieren des Flows in node-red?
                                        Kann mir nur vorstellen, dass Du nicht den ganzen Flow markiert hast ausversehen und da jetzt z.B. das Ende fehlt. Guck dir das mal an, eine andere Idee habe ich gerade nicht.

                                        Was mir gerade noch auffällt: Deine Error-Message enthält das Wort "falsch". Das taucht aber im gesamten Flow nicht auf. Nur das englische Wort "false". Kann es sein, dass dein Browser Englisch automatisch übersetzt? Dann wäre der Flow nämlich nicht zu gebrauchen. Lade den Flow mal runter und öffne ihn in einem Textdokument, nicht im Browser.

                                        Z 2 Antworten Letzte Antwort
                                        0
                                        • W warp-it

                                          @madmat17

                                          Hi Mat,

                                          das möchte ich auch versuchen, da auch bei mir mit dem ursprünglichen Flow reichlich Logeinträge entstehen:

                                          2023-03-16 16_32_14-logs - IoBroker.jpg

                                          Allerdings komme ich mit dem Parsing nicht klar, vielleicht kannst Du da noch mal ein Beispiel oder Screencopy beisteuern. Du schreibst 'edit puffer-parser'. Ist das etwas anderes als der normale 'buffer-parser' den ich in der linken Spalte finde?

                                          Viele Grüße
                                          Heinrich

                                          J Offline
                                          J Offline
                                          joschipp
                                          schrieb am zuletzt editiert von
                                          #202

                                          @warp-it
                                          Die Warnings bekommst du weg, indem du node-red-contrib-modbus updatest.

                                          Ich hab das auf der Kommandozeile gemacht:
                                          mit npm outdated werden veraltete Packages anzeigezeigt,
                                          outdated.PNG

                                          mit npm update node-red-contrib-modbus erfolgt das Update.
                                          Danach hatte ich keine Einträge mehr.
                                          VG

                                          mickymM 1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          709

                                          Online

                                          32.4k

                                          Benutzer

                                          81.4k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe