NEWS
[HowTo] Huawei SUN2000 WR Modbus mit node-red (read + write)
-
Leider funktioniert es doch nicht so wie erhofft. Wenn ich den Flow (egal welchen) starte, dann erhalte ich 1x Werte. Aus Verzweiflung habe ich Node Red aus meinem IOBroker entfernt und neu installiert und die Flows neu importiert …. Alles ohne Erfolg - die MODBUS Kommunikation zickt. Zwischenzeitlich habe ich ein paar Debug Informationen, Kann mir jemand etwas dazu sagen?
-
Hallo,
ich bekomme seit dem ich meine Wallbox installiert haben, folgende Fehlermeldung:
2023-07-31 16:03:34.176 warn 31 Jul 16:03:34 - [warn] [modbus-getter:32066] Modbus Failure On State sending Get More About It By Logging 31 Jul 16:03:34 - [warn] [modbus-getter:37101] Modbus Failure On State sending Get More About It By Logging 31 Jul 16:03:34 - [warn] [modbus-getter:30070] Modbus Failure On State sending Get More About It By Logging 31 Jul 16:03:34 - [warn] [modbus-getter:37765] Modbus Failure On State sending Get More About It By Logging node-red.0 2023-07-31 16:03:34.176 warn 31 Jul 16:03:34 - [warn] [modbus-getter:32080] Modbus Failure On State sending Get More About It By Logging
kann mir jemand helfen?
-
@homewolf
Läuft die Wallbox (welche isses denn?) auch auf ModBus? Vielleicht auf demselben Port? Dann könnte ich mir vorstellen, dass die sich blockieren. -
@badsnoopy667 ist die von Huawei 22 kw
-
Hallo,
vielen Dank für dieses Node-Red "Ready-to-use"-Paket. Ein wenig Anpassung und es läuft problemlos.
Nun versuche ich die gewonnenen Daten anzuzeigen und zu verstehen. Insbesondere möchte ich aus diesen Daten ein Dashboard aufbauen@ple
Ich würde sehr gerne dein Grafana-Dashboard nutzen. Was muss ich dafür tun?
Wenn ich das JSON importiere bleibt alles leer.
Wenn ich die Felder Editiere steht da nichts drin. Muss ich die Datenquelle vor dem Import bereits richtig anlegen? Wie muss die aussehen?
Gruß,
Christian -
@badsnoopy667ja laufen beide auf 502... aber das ist doch auch richtig oder?
-
@edde
Hallo alle miteinander!
Ich habe über Modbus aktuell meine Werte aus der Anlage ausgelesen und gebe diese in entsprechende Homematic-Systemvariablen aus.Da ich hier beim Vergleichen mit den Werten aus der Online-Fusionsolar-Anzeige teilweise nicht ganz erklärliche Differenzen bzw. Unterschiede feststellen musste: liege ich hier richtig oder habe ich hier noch Interpretationsfehler?
- aktueller PV-Ertrag (das was vom Dach kommt): 32064 Input Power
- PV-Gesamtertrag: 32106 Accumulated energy yield
- PV-Tagesertrag: 32114 Daily energy yield
- Akku-Ladestand: 37004 Energy storage
- Akku-Ladung des Tages: 37015 current day charge capacity
- Akku-Entladung des Tages: 37017 current day discharge capacity
- In/aus Netz: 37113 Active Power Meter
- Hauslast aktuell: 32080 Active Power Inverter - 37113 (in/aus Netz)
- Gesamtexport ins Netz: 37119 Positive active electricity
- Gesamteigenverbrauch PV: 32106 (PV-Gesamtertrag) abzüglich 37119 (Gesamtexport ins Netz)
- Gesamtverbrauch Strom: PV-Gesamtertrag + Gesamtexport ins Netz + 37121 Reverse active Power (Ges.import aus Netz)
Viele Grüße
-
Hi Leute ich hab bei mir Optimierer verbaut in beiden Strings. Ist es evtl. auch möglich davon Daten zu bekommen?
-
Kann jemand mit der Fehlermeldung was anfangen? Egal was ich umstelle. nichts hilft
State value to set for "0_userdata.0.Huawei.Inverter.Model" has to be stringified but received type "object"
-
@homewolf sagte in [HowTo] Huawei SUN2000 WR Modbus mit node-red (read + write):
Kann jemand mit der Fehlermeldung was anfangen? Egal was ich umstelle. nichts hilft
State value to set for "0_userdata.0.Huawei.Inverter.Model" has to be stringified but received type "object"
Dein Datenpunkt ist vom Typ String aber du empfängst Daten vom Typ Object.
Du kannst den Datentyp im Datenpunkt manuell auf object ändern, dann sollte der Fehler weg sein. -
@atifan wo stell ich das ein ?
im Objekt steht folgendes
{ "common": { "read": false, "write": true, "desc": "Created by Node-Red", "role": "Text", "name": "Huawei", "type": "object" }, "native": {}, "type": "state", "_id": "0_userdata.0.Huawei.Inverter.Model", "from": "system.adapter.admin.0", "user": "system.user.admin", "ts": 1691774042770
-
@homewolf Ja Du musst das Objekt stringifizieren. Schalte einfach eine JSON Node davor. Mach den Datenpunkt entweder als String oder als JSON.
-
@mickym sorry aber ich bin ein absoluter Neuling auf dem Gebiet. Ich bekomm es leider nicht hin, kannst du mir ein Beispiel schicken ? So sieht es aktuell bei mir aus.
-
Momentan bekommst Du das als Ergebnis raus, also ein Array mit einem Element.
Ein Array kommt deshalb raus, weil Du es so in Deiner Ausgabe spezifiziert hast.
Also dem Element 0. Wenn Du aus dem Array nur den String als payload in die iobroker Out Node schreiben willst, dann extrahierst Du dieses Element mit einer Change NOde.
So schreibst Du nur das 1. Element (Index 0) in Deine iobroker Out Node. Nun ist es KEIN Objekt mehr sondern nur der String.
Wenn Du mehrere Ausgaben hast, weil Du mehr parsed und Du willst das Array oder Objekt in einen Datenbunkt schreiben dann machst Du eine JSON Node davor - dann wird Dein Array stringifiziert - also ein JSON String erzeugt.
So kannst Du Objekte in einen iobroker Datenpunkt schreiben, wenn Du ein komplexeres Objekt hast.
===========================================================================================
DIE EINFACHSTE LÖSUNG ist, wenn Du Dir einfach mehrfache Ergebnisse ausgeben lässt. Da Du nur EINES hast, brauchst Du dann gar KEINE Node mehr dazwischen. So kannst Du das Ergebnis direkt in die iobroker-Out Node schreiben.
Wenn Du Dir also mehrfache Ergebnisse ausgeben lässt, dann macht die Buffer Node Dir einzelne Nachrichten und in diesem Fall direkt den String.
Ich hoffe ich konnte nun KLARHEIT in die Funktionsweise der Parser Node und deren Ausgabe bringen.
Nur zur Info, wenn Du einzelne Nachrichten haben willst - Du aber mehrfache hast kannst Du auch das topic setzen und in das Nachrichtenobjekt mit aufnehmen lassen.
Nun könntest Du auch mehrere Ausgaben haben und diese mit EINER iobroker-Out Node in mehrere Datenpunkte schreiben.
Statt das topic nun Model und Bezeichnung zu nennen, könntest Du nun als Topic den Pfad zum Datenpunkt angeben. Wenn Du also in der iobroker-Out Node das topic weglässt, kann es auch aus dem Nachrichtenobjekt genommen werden:
Ich würde auch ReadOnly nehmen und value - dann werden die Datenpunkte auch erstellt, wenn Du es in der Adapterkonfiguration zulässt. So kannst Du quasi direkt aus der Buffer Parser Node mehrere Datenpunkte gleichzeitig beschreiben:Wie Du siehst funktioniert das einwandfrei:
So ich glaube nun solltest Du genügend Anregung haben. Zur besseren Übersichtlichkeit könnte man aber auch die Namen Model und Bezeichnung lassen und den Pfad zum Datenpunkt mit einer Change Node ergänzen. Aber hier gibt es einfach mehrere Wege die zum Ziel führen und sind dann auch Geschmackssache.
=========================================================================
Ich will Dich aber nicht verwirren - für Dein Problem - einfach die Parser Node wie anfangs beschrieben einfach umstellen:
Das topic brauchst Du dann nicht - da Du es ja in Deiner iobroker-Out Node eingegeben hast.
-
@jwedenig said in [HowTo] Huawei SUN2000 WR Modbus mit node-red (read + write):
Habe seit gestern Probleme, meine Daten auszulesen!
Kennt wer diese Fehlermeldung?:Gibt es hierfür eine Lösung, ? habe gesehen, das bei mir auch einige Werte nicht mehr geschrieben werden seit längere Zeit....
Ab Register 32072 taucht das Problem auf? Wurde eventuell beim Update die Register geändert?
-
@drlange said in [HowTo] Huawei SUN2000 WR Modbus mit node-red (read + write):
PV-Gesamtertrag: 32106 Accumulated energy yield
Der Wert passt bei mir nicht.
Ich habe jeweils die Differenz von einem Tag zum nächsten genommen und bekomme unplausible Werte.
Jetzt habe ich mal für ein paar Tage die Daten aus der Datenbank (oben) und aus der App (unten) verglichen. Ich verstehe nicht, was 32106 bei mir bedeutet. Hat jemand eine Idee?
#edit: ein Problem ist identifiziert. Nicht alle Wechselrichter schicken ihre Daten
-
Um Klarheit zu schaffen habe ich nun auch noch die Tagesleistung hinzugefügt und die berechnete Leistung aus Arbeit * Zeit. Leider führt das nur zu noch mehr Verwirrung.
Hat schon jemand das Rätsel gelöst und es tatsächlich geschafft die Daten mit der App in Deckung zu bringen?
#edit: ein Problem ist identifiziert. Nicht alle Wechselrichter schicken ihre Daten
-
Seit ein paar Tagen habe ich ein PV-Anlage des Anbieters EnPAL mit dem SUN2000. Ich bin seither auf der Suche nach einer Lösung um die wesentlichen Daten (Erzeugung, Einspeisung etc) auslesen zu können. Bin in dem Bereich aber noch sehr neu und habe bisher um Node-red einen großen Bogen gemacht und bin auf diesen Thread gekommen.
Funktioniert diese Lösung grundsätzlich auch mit EnPAL Installationen ? Die installieren ja auch ein Kommunikationsmodul und werten die WR Daten in ihrem RZ aus.
Kann ich den WLAN-FE-Dongle nach meinen Bedürfnissen verändern oder ist der schon von EnPal im Gebrauch ? Aktuell sendet der WLAN-FE auf 192.168.200.2 (nicht mein WLAN)
Kann jemand zu der Thematik was sagen ? -
also ein Problem habe ich identifiziert: Der Inverter 2 liefert keine Daten. (dann ist ganz logisch, dass der Gesamtertrag nicht passt)
Ich konnte allerdings noch nicht klären, warum ich von Inverter 2 keine Daten bekomme. Die Einstellungen im Modbus-Getter müssten identisch sein und nur die Unit-ID eins mehr - oder?
Unit-ID 0 oder 3 liefert auch nix - habe ich probiert.Kann das noch ein Einstellungsproblem in Node-Red sein oder liegt der Fehler im Inverter?
-
Ich möchte mich rechtzeitig herzlich bei Euch allen, besonders beim Threadersteller, Spexx und mickym bedanken.
Dank diesem Thread war es ein Leichtes, die Daten in den ioBrocker zu bekommen.
Bisher habe ich mir die Daten der PV-Anlage zwecks Überschuss-Steuerung mehr oder weniger zuverlässig über das Projekt „Solaranzeige“ gezogen und mit Homematic weiterverarbeitet.Mit dieser Lösung hier stehen aber viel einfacher viel mehr Daten zuverlässig zur Verfügung. TOP!!
Viele Grüße
Maik