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. ioBroker Allgemein
  4. Huawei Sun2000 & ioBroker via JS script funktioniert

NEWS

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

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

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

Huawei Sun2000 & ioBroker via JS script funktioniert

Geplant Angeheftet Gesperrt Verschoben ioBroker Allgemein
481 Beiträge 62 Kommentatoren 121.2k Aufrufe 63 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.
  • R rainereglinsky

    @rainereglinsky Hilfe!
    hatte bis gestern ein toll funktionierenden Raspi 4 mit dem JS script laufen - alles war gut. Habe dann den Raspi fertig gemacht für den headless Betrieb - immer noch alles bestens.
    Heute bekomme ich keine Daten mehr aus meiner Sun 2000 ausgelesen - nur Fehlermeldungen. Habe schon das Backup von gestern neu eingespielt - gleiche Ergebnis.
    Auf meinem PC läuft das gleiche Script - ohne Probleme - alle Werte werden angezeigt.
    Hat jemand eine Idee????

    Hier Teile des Protokolls
    avascript.0
    2023-09-01 15:50:03.304 warn script.js.Huawei_Sun: Error received reading address 38200 from id: 1 with error: undefined

    javascript.0
    2023-09-01 15:49:58.303 warn script.js.Huawei_Sun: Error received reading address 37700 from id: 1 with error: undefined

    javascript.0
    2023-09-01 15:49:53.302 warn script.js.Huawei_Sun: Error received reading address 37100 from id: 1 with error: undefined

    javascript.0
    2023-09-01 15:49:48.303 warn script.js.Huawei_Sun: Error received reading address 37000 from id: 1 with error: undefined

    admin.0
    2023-09-01 15:49:46.330 info <== Disconnect system.user.admin from ::ffff:192.168.178.99 javascript

    admin.0
    2023-09-01 15:49:46.330 info <== Disconnect system.user.admin from ::ffff:192.168.178.99 javascript

    admin.0
    2023-09-01 15:49:45.445 info ==> Connected system.user.admin from ::ffff:192.168.178.99

    javascript.0
    2023-09-01 15:49:43.302 warn script.js.Huawei_Sun: Error received reading address 32000 from id: 1 with error: undefined

    javascript.0
    2023-09-01 15:49:38.302 warn script.js.Huawei_Sun: Error received reading address 38200 from id: 1 with error: undefined

    javascript.0
    2023-09-01 15:49:33.302 warn script.js.Huawei_Sun: Error received reading address 37700 from id: 1 with error: undefined

    javascript.0
    2023-09-01 15:49:28.302 warn script.js.Huawei_Sun: Error received reading address 37100 from id: 1 with error: undefined

    javascript.0
    2023-09-01 15:49:23.301 warn script.js.Huawei_Sun: Error received reading address 37000 from id: 1 with error: undefined

    javascript.0
    2023-09-01 15:49:18.301 warn script.js.Huawei_Sun: Error received reading address 32000 from id: 1 with error: undefined

    javascript.0
    2023-09-01 15:49:13.301 warn script.js.Huawei_Sun: Error received reading address 47081 from id: 1 with error: undefined

    javascript.0
    2023-09-01 15:49:08.301 warn script.js.Huawei_Sun: Error received reading address 38400 from id: 1 with error: undefined

    javascript.0
    2023-09-01 15:49:03.301 warn script.js.Huawei_Sun: Error received reading address 38300 from id: 1 with error: undefined

    javascript.0
    2023-09-01 15:48:58.301 warn script.js.Huawei_Sun: Error received reading address 37800 from id: 1 with error: undefined

    javascript.0
    2023-09-01 15:48:53.301 warn script.js.Huawei_Sun: Error received reading address 30000 from id: 1 with error: undefined

    javascript.0
    2023-09-01 15:48:48.300 warn script.js.Huawei_Sun: Error received reading address 38200 from id: 1 with error: undefined

    javascript.0
    2023-09-01 15:48:43.300 warn script.js.Huawei_Sun: Error received reading address 37700 from id: 1 with error: undefined

    javascript.0
    2023-09-01 15:48:38.300 warn script.js.Huawei_Sun: Error received reading address 37100 from id: 1 with error: undefined

    javascript.0
    2023-09-01 15:48:33.299 warn script.js.Huawei_Sun: Error received reading address 37000 from id: 1 with error: undefined

    javascript.0
    2023-09-01 15:48:28.299 warn script.js.Huawei_Sun: Error received reading address 32000 from id: 1 with error: undefined

    javascript.0
    2023-09-01 15:48:23.299 warn script.js.Huawei_Sun: Error received reading address 38200 from id: 1 with error: undefined

    javascript.0
    2023-09-01 15:48:18.299 warn script.js.Huawei_Sun: Error received reading address 37700 from id: 1 with error: undefined

    javascript.0
    2023-09-01 15:48:13.299 warn script.js.Huawei_Sun: Error received reading address 37100 from id: 1 with error: undefined

    javascript.0
    2023-09-01 15:48:08.299 warn script.js.Huawei_Sun: Error received reading address 37000 from id: 1 with error: undefined

    javascript.0
    2023-09-01 15:48:03.299 warn script.js.Huawei_Sun: Error received reading address 32000 from id: 1 with error: undefined

    javascript.0
    2023-09-01 15:47:58.298 warn script.js.Huawei_Sun: Error received reading address 38200 from id: 1 with error: undefined

    javascript.0
    2023-09-01 15:47:53.298 warn script.js.Huawei_Sun: Error received reading address 37700 from id: 1 with error: undefined

    J Offline
    J Offline
    juggi1962
    schrieb am zuletzt editiert von juggi1962
    #381

    @rainereglinsky du könntest das was R4 weiter oben geschrieben hat probieren.

    Du könntest versuchen in der Funktion readRegisterSpace() den auskommentierten Bereich zu aktivieren, also:

    function readRegisterSpace(id, address, length)

    
    
    function readRegisterSpace(id, address, length)
    
    //---------------------------------------------
    
     {
    
        client.setID(ModBusIDs[id-1]);
    
        client.readHoldingRegisters(address, length, function(err, data)
    
        {   
    
            if (err)
    
            {   
    
                if (err.modbusCode == null)
    
                {   console.warn("Lost connection to client. Trying to reconnect...");
    
                    ConnectModbus();
    
                } else             
    
                console.warn("Error received reading address " + address + " from id: " + ModBusIDs[id-1] + " with error: " + modbusErrorMessages[err.modbusCode]);            
    
            }
    
            else
    
            {   //console.debug("Read data from id/address " + ModBusIDs[id-1] + "/" + address + "\nData is: " + data.data);
    
                for (var i = 0; i < length; i++) Buffer[id-1][address + i - BufOffset] = data.data[i];
    
            }
    
        });
    
    }
    
    
    1 Antwort Letzte Antwort
    0
    • bahnuhrB Online
      bahnuhrB Online
      bahnuhr
      Forum Testing Most Active
      schrieb am zuletzt editiert von
      #382

      Guten Tag,
      ich bräuchte mal Hilfe bei den Einstellungen.

      Hardware:

      • WR SUN2000-8KTL-M1
        2 Strings
        Battery 15 kWh mit 3 Modulen
        Energy Meter
      • WR SUN2000-6KTL-M1
        1 String

      anbei Bild von Fusionsolar:
      90eaebbf-9a8e-4621-9c1e-158e366a2066-image.png

      Die Verbindung zeigt connected.

      Könnt ihr mir mal sagen was einstellen ist (außer der IP).
      Also hier:

      var currentinverter = 2;
      

      oder hier:

      // Enter the Modbus-IDs of your Sun2000 inverters here (example for two inverters): const ModBusIDs = [16, 1];
      const ModBusIDs = [1];
      

      Ich weißt die ID nicht ?!

      oder hier:

      const BatteryUnits = [[3, 0]];
      

      Hab schon mit allem möglichen rum probiert.
      Irgendwie fehlen viele Werte und manche sind nicht plausibel.


      Wenn ich helfen konnte, dann Daumen hoch (Pfeil nach oben)!
      Danke.
      gute Forenbeiträge: https://forum.iobroker.net/topic/51555/hinweise-f%C3%BCr-gute-forenbeitr%C3%A4ge
      ScreenToGif :https://www.screentogif.com/downloads.html

      1 Antwort Letzte Antwort
      0
      • bahnuhrB Online
        bahnuhrB Online
        bahnuhr
        Forum Testing Most Active
        schrieb am zuletzt editiert von
        #383

        @Chris-b

        Könntest du mir da helfen ?


        Wenn ich helfen konnte, dann Daumen hoch (Pfeil nach oben)!
        Danke.
        gute Forenbeiträge: https://forum.iobroker.net/topic/51555/hinweise-f%C3%BCr-gute-forenbeitr%C3%A4ge
        ScreenToGif :https://www.screentogif.com/downloads.html

        C 1 Antwort Letzte Antwort
        0
        • bahnuhrB bahnuhr

          @Chris-b

          Könntest du mir da helfen ?

          C Offline
          C Offline
          Chris_B
          schrieb am zuletzt editiert von
          #384

          @bahnuhr Hallo - ich glaube der einzige wirkliche Fehler ist, dass Du zwar zwei Strings, aber 'nur' einen Inverter hast. In diesem Sinne müsste folgendes gesetzt sein:

          var currentinverter = 1;
          
          // Enter the Modbus-IDs of your Sun2000 inverters here (example for two inverters): const ModBusIDs = [16, 1];
          const ModBusIDs = [1];
          // On which Modbus-ID can we reach the power meter? (via Sun2000!)
          const PowerMeterID = 0;
          // Enter your battery stack setup. 2 dimensional array, e.g. [[3, 2], [3, 0]] means:
          // First inverter has two battery stacks with 3 + 2 battery modules
          // while second inverter has only one battery stack with 3 battery modules
          const BatteryUnits = [[3, 0]];
          

          Das Setup entspricht eigentlich fast meinem Setup, einzig, dass ich nur einen String habe.
          Jetzt müsste man schauen was an Fehlermeldungen kommen. Und beachte: Gewisse Werte sind erst nach einmal Durchlaufen von Mitternacht wirklich sinnvoll.
          Gruss

          bahnuhrB 1 Antwort Letzte Antwort
          0
          • C Chris_B

            @bahnuhr Hallo - ich glaube der einzige wirkliche Fehler ist, dass Du zwar zwei Strings, aber 'nur' einen Inverter hast. In diesem Sinne müsste folgendes gesetzt sein:

            var currentinverter = 1;
            
            // Enter the Modbus-IDs of your Sun2000 inverters here (example for two inverters): const ModBusIDs = [16, 1];
            const ModBusIDs = [1];
            // On which Modbus-ID can we reach the power meter? (via Sun2000!)
            const PowerMeterID = 0;
            // Enter your battery stack setup. 2 dimensional array, e.g. [[3, 2], [3, 0]] means:
            // First inverter has two battery stacks with 3 + 2 battery modules
            // while second inverter has only one battery stack with 3 battery modules
            const BatteryUnits = [[3, 0]];
            

            Das Setup entspricht eigentlich fast meinem Setup, einzig, dass ich nur einen String habe.
            Jetzt müsste man schauen was an Fehlermeldungen kommen. Und beachte: Gewisse Werte sind erst nach einmal Durchlaufen von Mitternacht wirklich sinnvoll.
            Gruss

            bahnuhrB Online
            bahnuhrB Online
            bahnuhr
            Forum Testing Most Active
            schrieb am zuletzt editiert von
            #385

            @chris_b
            Ne ich habe 2 WR und insgesamt 3 Strings.

            WR 1: 2 Strings
            WR 2: 1 String


            Wenn ich helfen konnte, dann Daumen hoch (Pfeil nach oben)!
            Danke.
            gute Forenbeiträge: https://forum.iobroker.net/topic/51555/hinweise-f%C3%BCr-gute-forenbeitr%C3%A4ge
            ScreenToGif :https://www.screentogif.com/downloads.html

            B C 2 Antworten Letzte Antwort
            0
            • bahnuhrB bahnuhr

              @chris_b
              Ne ich habe 2 WR und insgesamt 3 Strings.

              WR 1: 2 Strings
              WR 2: 1 String

              B Offline
              B Offline
              baerengraben
              schrieb am zuletzt editiert von
              #386

              @bahnuhr Ich habe 2 WR, insgesamt 4 Strings und keine Batterie.

              Meine funktionierende Konfig:

              var currentinverter = 1;
              // Enter your inverter modbus IP and port here
              const ModBusPort = 502;
              const ModBusHost = "192.168.x.x"; //Dongle-IP auf WR1 (Master)
              const ModBusIDs = [1,2]; //Gem. Einstellung auf den WRs
              const PowerMeterID = 0;
              const BatteryUnits = [[0]];
              
              // These register spaces need to be read
              const RegToRead = 
              [ [32000, 116],   // inverter status -                            read fast
                [37000, 68],    // battery information -                        read fast
                [37100, 114],   // meter info -                                 read fast
                [37700, 100],   // battery information -                        read fast
                [38200, 100],   // additional battery information -             read fast
                [30000, 81],    // model info, SN, max Power (static info) -    read slow
              //  [37800, 100],   // additional battery information -             read slow
              //  [38300, 100],   // additional battery information -             read slow
              //  [38400, 100],   // additional battery information -             read slow
              //  [47081, 2]      // additional battery information -             read slow
              //[35300, 40]     // inverter power adjustments -                 do not read
              ];  
              const RegFast = 5;      // number of register spaces to read fast (must be < RegToRead.length)
              const RegFastMod = 3;  // read slow registers every n'th time (mod operator)
              var RegReadCnt = 0;     // Loop counter
              var RegToReadPtr = 0;   // pointer to register spaces
              

              Ich habe dann auch im Code noch einiges bezüglich Batterie auskommentiert. Das Script funktioniert damit seit rund 2 Wochen ohne Probleme.

              Mir ist aufgefallen, dass du currentinverter auf 2 gesetzt hast. Das ist aus meiner Sicht nicht korrekt. Das ist ja nur der "Pointer" auf den zu verarbeitenden Inverter, der hochgezählt wird.

              1 Antwort Letzte Antwort
              0
              • B Offline
                B Offline
                baerengraben
                schrieb am zuletzt editiert von
                #387

                @Chris_B Ich habe noch eine kleine Ergänzung für das Script. Die "Live-Daten" werden tiptop ausgelesen. Aber was mich eigentlich mindestens gleichviel interessiert, ist der aktuelle Status des Systems. Beispielsweise ist der Code für den WR-DeviceStatus vorhanden, nicht aber die konkrete Bedeutung des Codes. Ich habe hier dein Script bei mir folgendermassen ergänzt. Evtl. kannst du das für dich auch gebrauchen:

                // Zusätzliche States
                createState(JavaInst + "Solarpower.Huawei.Inverter.1.DeviceStatusName",   "",  {read: true, write: true, name: "Inverter 1 - Device Status Name"});
                
                    // Setze Device-Status Namen
                    // Inverter 1
                    var deviceStatusName = "";
                    switch (getState(JavaInst + SHI + "1.DeviceStatus").val)
                    {
                        case 0: deviceStatusName = "Initializing";break;
                        case 1: deviceStatusName = "Detecting ISO";break;
                        case 2: deviceStatusName = "Detecting irradiation";break;
                        case 3: deviceStatusName = "Grid detecting";break;
                        case 256: deviceStatusName = "Starting";break;
                        case 512: deviceStatusName = "On grid";break;
                        case 513: deviceStatusName = "On grid Power limit";break;
                        case 514: deviceStatusName = "On grid self derating";break;
                        case 768: deviceStatusName = "Shutdown fault";break;
                        case 769: deviceStatusName = "Shutdown command";break;
                        case 770: deviceStatusName = "Shutdown OVGR";break;
                        case 771: deviceStatusName = "Shutdown communication disconnected";break;
                        case 772: deviceStatusName = "Shutdown power limit";break;
                        case 773: deviceStatusName = "Shutdown start manually";break;
                        case 774: deviceStatusName = "Shutdown DC switch OFF";break;
                        case 1025: deviceStatusName = "Grid dispatch cos(Phi)-P curve";break;
                        case 1026: deviceStatusName = "Grid dispatch Q-U curve";break;
                        case 1280: deviceStatusName = "Spot-check";break;
                        case 1281: deviceStatusName = "Spot-checking";break;
                        case 1536: deviceStatusName = "Inspecting";break;
                        case 1792: deviceStatusName = "AFCI self-check";break;
                        case 2048: deviceStatusName = "I V scanning";break;
                        case 2304: deviceStatusName =" DC input detection";break;
                        case 40960: deviceStatusName = "No irradiation";break;
                        default: deviceStatusName = "undefined";break;
                        }
                    setState(JavaInst + SHI + "1.DeviceStatusName",  deviceStatusName);
                

                Zusätzlich wäre es auch super interessant die Bedeutungen von

                • SHI + id + ".State1
                • SHI + id + ".State2
                • SHI + id + ".State3
                • SHI + id + ".Alarm1
                • SHI + id + ".Alarm2
                • SHI + id + ".Alarm3
                • SHI + id + ".FaultCode"

                konkret zu kennen. Da bin ich aber noch nicht wirklich aus der Doku schlau geworden.

                C 1 Antwort Letzte Antwort
                0
                • bahnuhrB bahnuhr

                  @chris_b
                  Ne ich habe 2 WR und insgesamt 3 Strings.

                  WR 1: 2 Strings
                  WR 2: 1 String

                  C Offline
                  C Offline
                  Chris_B
                  schrieb am zuletzt editiert von
                  #388

                  @bahnuhr OK, sorry, habe nicht gesehen, dass du 2 Inverter hast. Also, ausmeiner Sicht, müsste das dann so aussehen:

                  var currentinverter = 2;
                  // Enter the Modbus-IDs of your Sun2000 inverters here (example for two inverters): const ModBusIDs = [16, 1];
                  const ModBusIDs = [1, 2];
                  // On which Modbus-ID can we reach the power meter? (via Sun2000!)
                  const PowerMeterID = 0;
                  // Enter your battery stack setup. 2 dimensional array, e.g. [[3, 2], [3, 0]] means:
                  // First inverter has two battery stacks with 3 + 2 battery modules
                  // while second inverter has only one battery stack with 3 battery modules
                  const BatteryUnits = [[3, 0], [0, 0]];
                  

                  Der von @baerengraben angegebene Array für die BatteryUnits ist nicht korrekt. Es kann laufen, aber das Programm greift potentiell auf nicht definierte Daten zu. Es muss für jeden WR angegeben werden, wie der potentiell vorhandene Batterystack aufgebaut ist. In diesem Fall: Am ersten WR hängt ein einfacher Battery Stack mit 3 Modulen, am zweiten hängt nichts (und auch das sollte spezifiziert werden).
                  Wichtig: PowerMeterID sagt, an welchem WR das PowerMeter hängt. In diesem Fall am erste WR.
                  Was mir nicht ganz klar ist sind die ModBusIDs. Bei nur einem WR ist das [1], bei zwei würde ich es einmal wie von @baerengraben vorgeschlagen ausprobieren, oder sonst mit der zweiten Zahl spielen...
                  Gruss

                  Gruss

                  bahnuhrB 1 Antwort Letzte Antwort
                  0
                  • B baerengraben

                    @Chris_B Ich habe noch eine kleine Ergänzung für das Script. Die "Live-Daten" werden tiptop ausgelesen. Aber was mich eigentlich mindestens gleichviel interessiert, ist der aktuelle Status des Systems. Beispielsweise ist der Code für den WR-DeviceStatus vorhanden, nicht aber die konkrete Bedeutung des Codes. Ich habe hier dein Script bei mir folgendermassen ergänzt. Evtl. kannst du das für dich auch gebrauchen:

                    // Zusätzliche States
                    createState(JavaInst + "Solarpower.Huawei.Inverter.1.DeviceStatusName",   "",  {read: true, write: true, name: "Inverter 1 - Device Status Name"});
                    
                        // Setze Device-Status Namen
                        // Inverter 1
                        var deviceStatusName = "";
                        switch (getState(JavaInst + SHI + "1.DeviceStatus").val)
                        {
                            case 0: deviceStatusName = "Initializing";break;
                            case 1: deviceStatusName = "Detecting ISO";break;
                            case 2: deviceStatusName = "Detecting irradiation";break;
                            case 3: deviceStatusName = "Grid detecting";break;
                            case 256: deviceStatusName = "Starting";break;
                            case 512: deviceStatusName = "On grid";break;
                            case 513: deviceStatusName = "On grid Power limit";break;
                            case 514: deviceStatusName = "On grid self derating";break;
                            case 768: deviceStatusName = "Shutdown fault";break;
                            case 769: deviceStatusName = "Shutdown command";break;
                            case 770: deviceStatusName = "Shutdown OVGR";break;
                            case 771: deviceStatusName = "Shutdown communication disconnected";break;
                            case 772: deviceStatusName = "Shutdown power limit";break;
                            case 773: deviceStatusName = "Shutdown start manually";break;
                            case 774: deviceStatusName = "Shutdown DC switch OFF";break;
                            case 1025: deviceStatusName = "Grid dispatch cos(Phi)-P curve";break;
                            case 1026: deviceStatusName = "Grid dispatch Q-U curve";break;
                            case 1280: deviceStatusName = "Spot-check";break;
                            case 1281: deviceStatusName = "Spot-checking";break;
                            case 1536: deviceStatusName = "Inspecting";break;
                            case 1792: deviceStatusName = "AFCI self-check";break;
                            case 2048: deviceStatusName = "I V scanning";break;
                            case 2304: deviceStatusName =" DC input detection";break;
                            case 40960: deviceStatusName = "No irradiation";break;
                            default: deviceStatusName = "undefined";break;
                            }
                        setState(JavaInst + SHI + "1.DeviceStatusName",  deviceStatusName);
                    

                    Zusätzlich wäre es auch super interessant die Bedeutungen von

                    • SHI + id + ".State1
                    • SHI + id + ".State2
                    • SHI + id + ".State3
                    • SHI + id + ".Alarm1
                    • SHI + id + ".Alarm2
                    • SHI + id + ".Alarm3
                    • SHI + id + ".FaultCode"

                    konkret zu kennen. Da bin ich aber noch nicht wirklich aus der Doku schlau geworden.

                    C Offline
                    C Offline
                    Chris_B
                    schrieb am zuletzt editiert von
                    #389

                    @baerengraben Ja, das ist auch noch ein Ausbau den ich machen wollte. Ich schau mir das an. Danke und Gruss

                    1 Antwort Letzte Antwort
                    0
                    • P Offline
                      P Offline
                      palantin
                      schrieb am zuletzt editiert von palantin
                      #390

                      vorweg herzlichen Dank für die Erstellung des Scripts.

                      Ich bekomme sauber Daten aus den Wechselrichtern.

                      meine Konfiguration: zwei Sun2000 8+6 KTL über Kaskade an einem Dongle und ein Smartmeter ebenfalls am Haupt-Wechselrichter. Ich bekomme Daten ins Fusion solar, aber bekomme keine Modbus Daten vom SmartMeter.

                      0333bd10-8824-4d41-94e2-54bced3ef359-image.png

                      Wenn ich die PowerMeter id auf 0 setze, werden leere Datenpunkte erzeugt,
                      9530584b-020f-401a-bd85-736ebeb32987-image.png

                      Setzte ich die id auf 11, was das offenbar die ID des SmartMeters sein dürfte laut Handyapp im Installateursaccount, wird der ganze Ordner nicht geschrieben und ich erhalte den Fehler: d575302c-224a-45d1-adf2-ba9c991cea01-image.png

                      Habe jeweils vor- einem neuen Test den ganzen Objektbaum in ioBroker gelöscht.

                      Hatte schon jemand so ein Verhalten?

                      Ich verwende die letztversion des Scripts

                      // Enter your inverter modbus IP and port here
                      const ModBusPort = 502;
                      const ModBusHost = "192.168.1.137";
                      
                      ConnectModbus();
                      
                      // Enter the Modbus-IDs of your Sun2000 inverters here (example for two inverters): const ModBusIDs = [16, 1];
                      const ModBusIDs = [1, 16];
                      						  
                      // On which Modbus-ID can we reach the power meter? (via Sun2000!)
                      const PowerMeterID = 0;
                      // Enter your battery stack setup. 2 dimensional array, e.g. [[3, 2], [3, 0]] means:
                      // First inverter has two battery stacks with 3 + 2 battery modules
                      // while second inverter has only one battery stack with 3 battery modules
                      const BatteryUnits = [[3, 0]];
                      

                      Batterie verwende ich keine, daher habe ich ProcessBattery(i); auskommentiert in der Funktion ProcessData

                      1 Antwort Letzte Antwort
                      0
                      • C Chris_B

                        @bahnuhr OK, sorry, habe nicht gesehen, dass du 2 Inverter hast. Also, ausmeiner Sicht, müsste das dann so aussehen:

                        var currentinverter = 2;
                        // Enter the Modbus-IDs of your Sun2000 inverters here (example for two inverters): const ModBusIDs = [16, 1];
                        const ModBusIDs = [1, 2];
                        // On which Modbus-ID can we reach the power meter? (via Sun2000!)
                        const PowerMeterID = 0;
                        // Enter your battery stack setup. 2 dimensional array, e.g. [[3, 2], [3, 0]] means:
                        // First inverter has two battery stacks with 3 + 2 battery modules
                        // while second inverter has only one battery stack with 3 battery modules
                        const BatteryUnits = [[3, 0], [0, 0]];
                        

                        Der von @baerengraben angegebene Array für die BatteryUnits ist nicht korrekt. Es kann laufen, aber das Programm greift potentiell auf nicht definierte Daten zu. Es muss für jeden WR angegeben werden, wie der potentiell vorhandene Batterystack aufgebaut ist. In diesem Fall: Am ersten WR hängt ein einfacher Battery Stack mit 3 Modulen, am zweiten hängt nichts (und auch das sollte spezifiziert werden).
                        Wichtig: PowerMeterID sagt, an welchem WR das PowerMeter hängt. In diesem Fall am erste WR.
                        Was mir nicht ganz klar ist sind die ModBusIDs. Bei nur einem WR ist das [1], bei zwei würde ich es einmal wie von @baerengraben vorgeschlagen ausprobieren, oder sonst mit der zweiten Zahl spielen...
                        Gruss

                        Gruss

                        bahnuhrB Online
                        bahnuhrB Online
                        bahnuhr
                        Forum Testing Most Active
                        schrieb am zuletzt editiert von
                        #391

                        @chris_b
                        @baerengraben

                        So, habe nun folgendes eingestellt:
                        Bekomme nun sehr viele DP gefüllt.

                        var currentinverter = 2;
                        Const ModBusIDs = [16,1];
                        const PowerMeterID = 0;
                        const BatteryUnits = [[3, 0], [0, 0]];
                        

                        Bei diesen DP:

                        // These register spaces need to be read
                        const RegToRead = 
                        [ [32000, 116],   // inverter status -                            read fast
                          [37000, 68],    // battery information -                        read fast
                          [37100, 114],   // meter info -                                 read fast
                          [37700, 100],   // battery information -                        read fast
                          [38200, 100],   // additional battery information -             read fast
                          [30000, 81],    // model info, SN, max Power (static info) -    read slow
                          [37800, 100],   // additional battery information -             read slow
                          [38300, 100],   // additional battery information -             read slow
                          [38400, 100],   // additional battery information -             read slow
                          [47081, 8]      // additional battery information -             read slow
                        //[35300, 40]     // inverter power adjustments -                 do not read
                        ]; 
                        

                        kommen Fehler im log:

                        javascript.0
                        2023-09-08 16:20:57.915	warn	script.js.Scripte.Geraete.Huawei_geändert: Error received reading address 37700 from id: 1 with error: undefined
                        javascript.0
                        2023-09-08 16:20:52.915	warn	script.js.Scripte.Geraete.Huawei_geändert: Error received reading address 37100 from id: 1 with error: undefined
                        javascript.0
                        2023-09-08 16:20:47.914	warn	script.js.Scripte.Geraete.Huawei_geändert: Error received reading address 37000 from id: 1 with error: undefined
                        javascript.0
                        2023-09-08 16:20:42.915	warn	script.js.Scripte.Geraete.Huawei_geändert: Error received reading address 32000 from id: 1 with error: undefined
                        javascript.0
                        2023-09-08 16:20:37.915	warn	script.js.Scripte.Geraete.Huawei_geändert: Error received reading address 47081 from id: 16 with error: undefined
                        javascript.0
                        2023-09-08 16:20:32.914	warn	script.js.Scripte.Geraete.Huawei_geändert: Error received reading address 38400 from id: 16 with error: undefined
                        javascript.0
                        2023-09-08 16:20:27.915	warn	script.js.Scripte.Geraete.Huawei_geändert: Error received reading address 38300 from id: 16 with error: undefined
                        javascript.0
                        2023-09-08 16:20:27.883	warn	script.js.Scripte.Geraete.Huawei_Original_V4: Error received reading address 37700 from id: 16 with error: Slave device busy (retry request again later)
                        

                        Soll/kann ich die einfach auskommentieren.

                        mfg


                        Wenn ich helfen konnte, dann Daumen hoch (Pfeil nach oben)!
                        Danke.
                        gute Forenbeiträge: https://forum.iobroker.net/topic/51555/hinweise-f%C3%BCr-gute-forenbeitr%C3%A4ge
                        ScreenToGif :https://www.screentogif.com/downloads.html

                        P 1 Antwort Letzte Antwort
                        0
                        • J Offline
                          J Offline
                          jokerjo1000
                          schrieb am zuletzt editiert von
                          #392

                          Hallo zusammen,
                          ich hoffe ich darf das hier einmal schreiben?
                          Ich habe laienhafte Kenntnisse von der ganzen Materie, jedoch nicht ausreichend um hier mitzukommen.
                          Habe auch eine Huawei PV Anlage mit Wechselrichter Speicher und Power Meter. Auch ein Raspi mit Iobroker ist am laufen. Daten hole ich mir u.a. von Influx und evcc. Gerne würde ich die Modbus Daten in den Iobroker bekommen. Hier hört aber mein Wissenstand auf. Ihr schreibt hier viel was für Kenner etwas ist aber leider nicht für "Anfänger". Es wäre echt klasse wenn jemand vielleicht einmal Lust hat uns Laien etwas mitzunehmen. Habe versucht das Skript von Chris im Iobroker zu installieren, jedoch ohne Erfolg. Es haut lediglich nur Fehlermeldungen raus. Das liegt sicherlich an mir und ich würde mich freuen das auch einmal hin zu bekommen. Es wäre also schön wenn jemand uns Newbies etwas itnehmen könnte.

                          DANKE !!!

                          H 1 Antwort Letzte Antwort
                          0
                          • bahnuhrB bahnuhr

                            @chris_b
                            @baerengraben

                            So, habe nun folgendes eingestellt:
                            Bekomme nun sehr viele DP gefüllt.

                            var currentinverter = 2;
                            Const ModBusIDs = [16,1];
                            const PowerMeterID = 0;
                            const BatteryUnits = [[3, 0], [0, 0]];
                            

                            Bei diesen DP:

                            // These register spaces need to be read
                            const RegToRead = 
                            [ [32000, 116],   // inverter status -                            read fast
                              [37000, 68],    // battery information -                        read fast
                              [37100, 114],   // meter info -                                 read fast
                              [37700, 100],   // battery information -                        read fast
                              [38200, 100],   // additional battery information -             read fast
                              [30000, 81],    // model info, SN, max Power (static info) -    read slow
                              [37800, 100],   // additional battery information -             read slow
                              [38300, 100],   // additional battery information -             read slow
                              [38400, 100],   // additional battery information -             read slow
                              [47081, 8]      // additional battery information -             read slow
                            //[35300, 40]     // inverter power adjustments -                 do not read
                            ]; 
                            

                            kommen Fehler im log:

                            javascript.0
                            2023-09-08 16:20:57.915	warn	script.js.Scripte.Geraete.Huawei_geändert: Error received reading address 37700 from id: 1 with error: undefined
                            javascript.0
                            2023-09-08 16:20:52.915	warn	script.js.Scripte.Geraete.Huawei_geändert: Error received reading address 37100 from id: 1 with error: undefined
                            javascript.0
                            2023-09-08 16:20:47.914	warn	script.js.Scripte.Geraete.Huawei_geändert: Error received reading address 37000 from id: 1 with error: undefined
                            javascript.0
                            2023-09-08 16:20:42.915	warn	script.js.Scripte.Geraete.Huawei_geändert: Error received reading address 32000 from id: 1 with error: undefined
                            javascript.0
                            2023-09-08 16:20:37.915	warn	script.js.Scripte.Geraete.Huawei_geändert: Error received reading address 47081 from id: 16 with error: undefined
                            javascript.0
                            2023-09-08 16:20:32.914	warn	script.js.Scripte.Geraete.Huawei_geändert: Error received reading address 38400 from id: 16 with error: undefined
                            javascript.0
                            2023-09-08 16:20:27.915	warn	script.js.Scripte.Geraete.Huawei_geändert: Error received reading address 38300 from id: 16 with error: undefined
                            javascript.0
                            2023-09-08 16:20:27.883	warn	script.js.Scripte.Geraete.Huawei_Original_V4: Error received reading address 37700 from id: 16 with error: Slave device busy (retry request again later)
                            

                            Soll/kann ich die einfach auskommentieren.

                            mfg

                            P Offline
                            P Offline
                            palantin
                            schrieb am zuletzt editiert von
                            #393

                            @bahnuhr hast du Daten unter "Meter"

                            668cd20d-5480-4359-9ae4-0e2d98881737-image.png

                            bahnuhrB 1 Antwort Letzte Antwort
                            0
                            • P palantin

                              @bahnuhr hast du Daten unter "Meter"

                              668cd20d-5480-4359-9ae4-0e2d98881737-image.png

                              bahnuhrB Online
                              bahnuhrB Online
                              bahnuhr
                              Forum Testing Most Active
                              schrieb am zuletzt editiert von
                              #394

                              @palantin sagte in Huawei Sun2000 & ioBroker via JS script funktioniert:

                              hast du Daten unter "Meter"

                              ja, hat aber gedauert.


                              Wenn ich helfen konnte, dann Daumen hoch (Pfeil nach oben)!
                              Danke.
                              gute Forenbeiträge: https://forum.iobroker.net/topic/51555/hinweise-f%C3%BCr-gute-forenbeitr%C3%A4ge
                              ScreenToGif :https://www.screentogif.com/downloads.html

                              P 1 Antwort Letzte Antwort
                              0
                              • bahnuhrB bahnuhr

                                @palantin sagte in Huawei Sun2000 & ioBroker via JS script funktioniert:

                                hast du Daten unter "Meter"

                                ja, hat aber gedauert.

                                P Offline
                                P Offline
                                palantin
                                schrieb am zuletzt editiert von
                                #395

                                @bahnuhr
                                welche Kommunikationsid steht bei dir in der SolarApp von Huawei vom SmartMeter?

                                bahnuhrB 1 Antwort Letzte Antwort
                                0
                                • P palantin

                                  @bahnuhr
                                  welche Kommunikationsid steht bei dir in der SolarApp von Huawei vom SmartMeter?

                                  bahnuhrB Online
                                  bahnuhrB Online
                                  bahnuhr
                                  Forum Testing Most Active
                                  schrieb am zuletzt editiert von
                                  #396

                                  @palantin sagte in Huawei Sun2000 & ioBroker via JS script funktioniert:

                                  @bahnuhr
                                  welche Kommunikationsid steht bei dir in der SolarApp von Huawei vom SmartMeter?

                                  keine Ahnung was du meinst bzw. wo ich sowas finde


                                  Wenn ich helfen konnte, dann Daumen hoch (Pfeil nach oben)!
                                  Danke.
                                  gute Forenbeiträge: https://forum.iobroker.net/topic/51555/hinweise-f%C3%BCr-gute-forenbeitr%C3%A4ge
                                  ScreenToGif :https://www.screentogif.com/downloads.html

                                  1 Antwort Letzte Antwort
                                  0
                                  • J jokerjo1000

                                    Hallo zusammen,
                                    ich hoffe ich darf das hier einmal schreiben?
                                    Ich habe laienhafte Kenntnisse von der ganzen Materie, jedoch nicht ausreichend um hier mitzukommen.
                                    Habe auch eine Huawei PV Anlage mit Wechselrichter Speicher und Power Meter. Auch ein Raspi mit Iobroker ist am laufen. Daten hole ich mir u.a. von Influx und evcc. Gerne würde ich die Modbus Daten in den Iobroker bekommen. Hier hört aber mein Wissenstand auf. Ihr schreibt hier viel was für Kenner etwas ist aber leider nicht für "Anfänger". Es wäre echt klasse wenn jemand vielleicht einmal Lust hat uns Laien etwas mitzunehmen. Habe versucht das Skript von Chris im Iobroker zu installieren, jedoch ohne Erfolg. Es haut lediglich nur Fehlermeldungen raus. Das liegt sicherlich an mir und ich würde mich freuen das auch einmal hin zu bekommen. Es wäre also schön wenn jemand uns Newbies etwas itnehmen könnte.

                                    DANKE !!!

                                    H Offline
                                    H Offline
                                    hussi
                                    schrieb am zuletzt editiert von
                                    #397

                                    @jokerjo1000 Ich habe auch von Null angefangen. Evtl. kann ich dir Helfen.

                                    Der erste Schritt ist, dass du unter Instanzen in den Einstellungen von Javascript das NPM Modul "modbus-serial" hinzufügst. Dazu vorher:

                                    https://www.npmjs.com/package/modbus-serial

                                    Anschließend gehst du zu den Scripten und legst dir ein neues Javascript mit dem Inhalt von Chris´ github:

                                    https://github.com/ChrisBCH/SunLuna2000_iobroker

                                    Dann müssen in dem Script die Daten deiner PV Anlage eingegeben werden. IP, etc.

                                    Nun solltest du die Daten in den Objekten unter javascript > 0 > Solarpower sehen.

                                    1 Antwort Letzte Antwort
                                    0
                                    • B badsnoopy667

                                      @pettyboo
                                      Ich hab es jetzt hinbekommen Register zu schreiben! Ich kann jetzt die maximale Entladeleistung der Batterie auf 0 setzen wenn das eAuto lädt.
                                      Ich hab es mit node-red gemacht. Hier der Flow für das eine Register:

                                      flows.json

                                      Den Wert den man einstellen will, z.B. 400 Watt schreibt man in den SET Datenpunkt (vorher anlegen!). Das Hauptproblem ist, dass der Wert in zwei Register geschrieben werden muss. Also muss er aufgeteilt werden. Das macht der Funktions-Node im Flow. Einfach mal ausprobieren, ich glaub man kann nicht viel kaputt machen, falsche Werte nimmt der WR nicht an. (Ohne Garantie!)
                                      Hier nochmal die Modbus Interface Definitions V3, ohne die geht's nicht:
                                      https://forum.iobroker.net/assets/uploads/files/1624831109365-solar-inverter-modbus-interface-definitions-v3.0.pdf

                                      Viel Erfolg!

                                      0 Offline
                                      0 Offline
                                      0815_Peter
                                      schrieb am zuletzt editiert von
                                      #398

                                      @badsnoopy667

                                      Hallo in die Runde,

                                      vielleicht hab ich was überlesen bei den 395 Antworten, wenn ja bitte entschuldigt.

                                      Das schreiben der U32 Zahl (Maximum Charge and Discharge Power) funktioniert mit den Flow vom badsnoopy667 hab vielen dank.

                                      Wenn ich die % Werte der SOC Charge Cutoff und Discharge Cutoff einstellen will muss ich eine U16 Zahl schicken zum WR.
                                      Ich werde aus der Beschreibung für die Funktion im Flow nicht so richtig schlau.

                                      https://stevesnoderedguide.com/modbus-writing-data

                                      Das mit den GAIN habe ich schon beachtet --> eine 100 sind 10% --> trotzdem will der WR meine Werte nicht :-( also sollte es auch der Funktion liegen die den String aufarbeitet.
                                      Kann mir bitte jemand helfen wie die Funktion im Flow aussehen muss, damit der WR die % Werte annimmt die geschickt werden.

                                      Screenshot 2023-09-12 155420.png

                                      B 1 Antwort Letzte Antwort
                                      0
                                      • 0 0815_Peter

                                        @badsnoopy667

                                        Hallo in die Runde,

                                        vielleicht hab ich was überlesen bei den 395 Antworten, wenn ja bitte entschuldigt.

                                        Das schreiben der U32 Zahl (Maximum Charge and Discharge Power) funktioniert mit den Flow vom badsnoopy667 hab vielen dank.

                                        Wenn ich die % Werte der SOC Charge Cutoff und Discharge Cutoff einstellen will muss ich eine U16 Zahl schicken zum WR.
                                        Ich werde aus der Beschreibung für die Funktion im Flow nicht so richtig schlau.

                                        https://stevesnoderedguide.com/modbus-writing-data

                                        Das mit den GAIN habe ich schon beachtet --> eine 100 sind 10% --> trotzdem will der WR meine Werte nicht :-( also sollte es auch der Funktion liegen die den String aufarbeitet.
                                        Kann mir bitte jemand helfen wie die Funktion im Flow aussehen muss, damit der WR die % Werte annimmt die geschickt werden.

                                        Screenshot 2023-09-12 155420.png

                                        B Online
                                        B Online
                                        badsnoopy667
                                        schrieb am zuletzt editiert von
                                        #399

                                        @0815_peter
                                        Ich glaube Du hast in den falschen Thread gepostet.
                                        Aber versuch's mal hiermit:

                                        var fc = 16;
                                        var sa = 50;
                                        var addresses = 2;
                                        var buf = Buffer.alloc(2); // create a buffer with 2 bytes for UINT16
                                        buf.writeUInt16BE(msg.payload); // write UINT16 value to the buffer
                                        var value = buf.readUInt16BE(); // read the UINT16 value from the buffer
                                        msg.slave_ip = "192.168.1.76";
                                        msg.payload = value;
                                        return msg;
                                        
                                        1 Antwort Letzte Antwort
                                        0
                                        • 0 Offline
                                          0 Offline
                                          0815_Peter
                                          schrieb am zuletzt editiert von
                                          #400

                                          @badsnoopy667

                                          Danke für deine Antwort
                                          okay ich hab hier geantwortet, da du am Anfang von diesen Thread gezeigt hast wie du auf die Register schreibst.

                                          Leider klappt deine Funktion nicht...der WR nimmt die Werte nicht :-(

                                          ich hab meinen Flow mal hier angehangen vielleicht sieht du ja gleich den Fehler.

                                          flows.json

                                          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
                                          FAQ Cloud / IOT
                                          HowTo: Node.js-Update
                                          HowTo: Backup/Restore
                                          Downloads
                                          BLOG

                                          755

                                          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