NEWS
[HowTo] Huawei SUN2000 WR Modbus mit node-red (read + write)
-
Ich hatte weiter oben mein Blockly Script gepostet wo ich mir die ganzen fehlenden Werte selber errechne:
https://forum.iobroker.net/topic/51639/howto-huawei-sun2000-wr-modbus-mit-node-red-read-write/139
@badsnoopy667 Cool, vielen Dank! Hat mich gerade zwar etwas Arbeit gekostet weil deine Datenpunkte nicht automatisch angelegt werden, aber jetzt sieht es gut aus. :)
-
@badsnoopy667 Cool, vielen Dank! Hat mich gerade zwar etwas Arbeit gekostet weil deine Datenpunkte nicht automatisch angelegt werden, aber jetzt sieht es gut aus. :)
Hat schon mal jemand versucht, die Leistung des Wechselrichters über "write" zu drosseln oder den Wechselrichter abzuschalten? (Hab eine KTL30-M3)
Hintergrund ist, das ich DIY Akkus mit Victron am laufen hab, ich würde das Ganze aber gern Notstrom fähig machen. Dazu muß ich aber zwingend den Wechselrichter runterfahren können bzw. ganz abschalten. Faktor 1 Regel. -
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: Changeme2. 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-modbusHat 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: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 FirmwareVielen Dank an alle, die den Input geliefert haben!
Ich hoffe es hilf, wenn ich es hier einmal zusammengefasst habe.Ich habe schon seit langem das Problem, dass mir regelmäßig folgende Meldungen angezeigt werden. Dann wird der Abruf der Register abgebrochen. Ich bekomme manchmal mehr und manchmal weniger Daten bis zu der Meldung.
node-red.0 2023-02-24 20:55:11.124 warn 24 Feb 19:55:11 - [warn] [modbus-client:ModBus-TCP] Client -> fsm connected after state init Get More About It By Logging TCP@192.168.1.119:502 default Unit-Id: 1 node-red.0 2023-02-24 20:55:09.119 warn 24 Feb 19:55:09 - [warn] [modbus-client:ModBus-TCP] Client -> fsm init in 2000 ms TCP@192.168.1.119:502 default Unit-Id: 1 node-red.0 2023-02-24 20:55:09.119 warn 24 Feb 19:55:09 - [warn] [modbus-client:ModBus-TCP] Client -> fsm init state after reconnecting TCP@192.168.1.119:502 default Unit-Id: 1 node-red.0 2023-02-24 20:55:07.117 warn 24 Feb 19:55:07 - [warn] [modbus-client:ModBus-TCP] Client -> fsm broken state after failed Get More About It By Logging TCP@192.168.1.119:502 default Unit-Id: 1 24 Feb 19:55:07 - [warn] [modbus-client:ModBus-TCP] Client -> fsm reconnect state after broken Get More About It By Logging TCP@192.168.1.119:502 default Unit-Id: 1 node-red.0 2023-02-24 20:55:07.116 warn 24 Feb 19:55:07 - [warn] [modbus-client:ModBus-TCP] Client -> fsm failed state after sending Get More About It By Logging TCP@192.168.1.119:502 default Unit-Id: 1Mein Dongle ist auf Version 133
Meine WR (8KTL und 10KTL) auf Version 151
Die Batterie auf Version 118Hat jemand eine Idee woran es liegen kann?
Ich habe hier noch mal meine Version des Note-Red Skriptes angehängt. Dazu ist allerdings zusagen, dass ich auch mit dem Original diese Probleme habe.
Note-Red Modbus Huawei.txtDanke euch für die Hilfe.
-
Ich habe schon seit langem das Problem, dass mir regelmäßig folgende Meldungen angezeigt werden. Dann wird der Abruf der Register abgebrochen. Ich bekomme manchmal mehr und manchmal weniger Daten bis zu der Meldung.
node-red.0 2023-02-24 20:55:11.124 warn 24 Feb 19:55:11 - [warn] [modbus-client:ModBus-TCP] Client -> fsm connected after state init Get More About It By Logging TCP@192.168.1.119:502 default Unit-Id: 1 node-red.0 2023-02-24 20:55:09.119 warn 24 Feb 19:55:09 - [warn] [modbus-client:ModBus-TCP] Client -> fsm init in 2000 ms TCP@192.168.1.119:502 default Unit-Id: 1 node-red.0 2023-02-24 20:55:09.119 warn 24 Feb 19:55:09 - [warn] [modbus-client:ModBus-TCP] Client -> fsm init state after reconnecting TCP@192.168.1.119:502 default Unit-Id: 1 node-red.0 2023-02-24 20:55:07.117 warn 24 Feb 19:55:07 - [warn] [modbus-client:ModBus-TCP] Client -> fsm broken state after failed Get More About It By Logging TCP@192.168.1.119:502 default Unit-Id: 1 24 Feb 19:55:07 - [warn] [modbus-client:ModBus-TCP] Client -> fsm reconnect state after broken Get More About It By Logging TCP@192.168.1.119:502 default Unit-Id: 1 node-red.0 2023-02-24 20:55:07.116 warn 24 Feb 19:55:07 - [warn] [modbus-client:ModBus-TCP] Client -> fsm failed state after sending Get More About It By Logging TCP@192.168.1.119:502 default Unit-Id: 1Mein Dongle ist auf Version 133
Meine WR (8KTL und 10KTL) auf Version 151
Die Batterie auf Version 118Hat jemand eine Idee woran es liegen kann?
Ich habe hier noch mal meine Version des Note-Red Skriptes angehängt. Dazu ist allerdings zusagen, dass ich auch mit dem Original diese Probleme habe.
Note-Red Modbus Huawei.txtDanke euch für die Hilfe.
@a1uca2d
Hat der Dongle eine stabile WLAN Verbindung? Was anderes fällt mir dazu leider nicht ein. -
@a1uca2d
Hat der Dongle eine stabile WLAN Verbindung? Was anderes fällt mir dazu leider nicht ein.@badsnoopy667
Der dongle ist per LAN angeschlossen.
Daher sind WLAN kein Thema sein -
@badsnoopy667
Der dongle ist per LAN angeschlossen.
Daher sind WLAN kein Thema seinLeider schmeisst meine Node Red Instanz auch dann und wann komische Warnmeldungen die ich als Node Red Noob nicht verstehe.
Kann mir jemand erklären was dieser broken state ist?
Und wie ich das behebe?node-red.0 2023-02-27 19:45:41.128 warn 27 Feb 19:45:41 - [warn] [modbus-client:WLAN-FE] Client -> fsm broken state after failed Get More About It By Logging TCP@192.168.2.187:502 default Unit-Id: 1 node-red.0 2023-02-27 19:45:41.127 warn 27 Feb 19:45:41 - [warn] [modbus-client:WLAN-FE] Client -> fsm failed state after sending Get More About It By Logging TCP@192.168.2.187:502 default Unit-Id: 1 node-red.0 2023-02-27 19:45:18.552 warn 27 Feb 19:45:18 - [warn] [modbus-client:WLAN-FE] Client -> fsm failed state after sending Get More About It By Logging TCP@192.168.2.187:502 default Unit-Id: 1 27 Feb 19:45:18 - [warn] [modbus-client:WLAN-FE] Client -> fsm broken state after failed Get More About It By Logging TCP@192.168.2.187:502 default Unit-Id: 1 -
Leider schmeisst meine Node Red Instanz auch dann und wann komische Warnmeldungen die ich als Node Red Noob nicht verstehe.
Kann mir jemand erklären was dieser broken state ist?
Und wie ich das behebe?node-red.0 2023-02-27 19:45:41.128 warn 27 Feb 19:45:41 - [warn] [modbus-client:WLAN-FE] Client -> fsm broken state after failed Get More About It By Logging TCP@192.168.2.187:502 default Unit-Id: 1 node-red.0 2023-02-27 19:45:41.127 warn 27 Feb 19:45:41 - [warn] [modbus-client:WLAN-FE] Client -> fsm failed state after sending Get More About It By Logging TCP@192.168.2.187:502 default Unit-Id: 1 node-red.0 2023-02-27 19:45:18.552 warn 27 Feb 19:45:18 - [warn] [modbus-client:WLAN-FE] Client -> fsm failed state after sending Get More About It By Logging TCP@192.168.2.187:502 default Unit-Id: 1 27 Feb 19:45:18 - [warn] [modbus-client:WLAN-FE] Client -> fsm broken state after failed Get More About It By Logging TCP@192.168.2.187:502 default Unit-Id: 1@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.

Da habe ich die Meldung erhalten, dass der Controller zu viele anfragen bearbeiten musste.
Ich habe das Abfrageintervall nun auf 18Sek gesetzt.

Und hier mein überarbeiteter kompletter Flow:
Hat vielleicht jemand eine Idee, warum mein Dongle mit der "hohen" Abfragerate ein Problem hat und die anderen Teilnehmer im Forum wohl eher nicht?
-
@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.

Da habe ich die Meldung erhalten, dass der Controller zu viele anfragen bearbeiten musste.
Ich habe das Abfrageintervall nun auf 18Sek gesetzt.

Und hier mein überarbeiteter kompletter Flow:
Hat vielleicht jemand eine Idee, warum mein Dongle mit der "hohen" Abfragerate ein Problem hat und die anderen Teilnehmer im Forum wohl eher nicht?
Hallo,
ich versuche aktuell meinen SUN2000 WR mit node-red auszulesen.
beim Start von node-red bekommen ich folgende "warnings" im log:node-red.0 2023-03-03 11:11:31.544 warn 3 Mar 11:11:31 - [warn] [modbus-getter:30000] Getter -> Inject while node is not ready for input. node-red.0 2023-03-03 11:11:31.050 warn 3 Mar 11:11:31 - [warn] Verwende unverschlüsselte Credentials node-red.0 2023-03-03 11:11:04.662 info Starting node-red: --max-old-space-size=128 /opt/iobroker/node_modules/node-red/red.js -v --settings /opt/iobroker/iobroker-data/node-red/settings.js node-red.0 2023-03-03 11:11:00.476 info Requested NPM packages: ["node-red-contrib-calc","node-red-contrib-buffer-parser","node-red-contrib-modbus"] node-red.0 2023-03-03 11:11:00.382 info starting. Version 4.0.0 in /opt/iobroker/node_modules/iobroker.node-red, node: v16.17.1, js-controller: 4.0.23 node-red.0 2023-03-03 11:10:50.753 info Terminated (START_IMMEDIATELY_AFTER_STOP): Without reason node-red.0 2023-03-03 11:10:50.365 info starting. Version 4.0.0 in /opt/iobroker/node_modules/iobroker.node-red, node: v16.17.1, js-controller: 4.0.23was ist hier falsch? bin absoluter Neuling in "node-red"...
-
Hallo,
ich versuche aktuell meinen SUN2000 WR mit node-red auszulesen.
beim Start von node-red bekommen ich folgende "warnings" im log:node-red.0 2023-03-03 11:11:31.544 warn 3 Mar 11:11:31 - [warn] [modbus-getter:30000] Getter -> Inject while node is not ready for input. node-red.0 2023-03-03 11:11:31.050 warn 3 Mar 11:11:31 - [warn] Verwende unverschlüsselte Credentials node-red.0 2023-03-03 11:11:04.662 info Starting node-red: --max-old-space-size=128 /opt/iobroker/node_modules/node-red/red.js -v --settings /opt/iobroker/iobroker-data/node-red/settings.js node-red.0 2023-03-03 11:11:00.476 info Requested NPM packages: ["node-red-contrib-calc","node-red-contrib-buffer-parser","node-red-contrib-modbus"] node-red.0 2023-03-03 11:11:00.382 info starting. Version 4.0.0 in /opt/iobroker/node_modules/iobroker.node-red, node: v16.17.1, js-controller: 4.0.23 node-red.0 2023-03-03 11:10:50.753 info Terminated (START_IMMEDIATELY_AFTER_STOP): Without reason node-red.0 2023-03-03 11:10:50.365 info starting. Version 4.0.0 in /opt/iobroker/node_modules/iobroker.node-red, node: v16.17.1, js-controller: 4.0.23was ist hier falsch? bin absoluter Neuling in "node-red"...
@stoffel67
Ich glaube du musst die drei NPM Packages noch in der Instanz hinzufügen. Habe ich im ersten Post beschrieben. -
@stoffel67
Ich glaube du musst die drei NPM Packages noch in der Instanz hinzufügen. Habe ich im ersten Post beschrieben.@badsnoopy667
Die müßte ich doch drin haben

-
@badsnoopy667
Die müßte ich doch drin haben

-
Ohh, im Dongle war ModBus-TCP nicht aktiviert…
Und schon gehts…allerdings sehr wenig Werte, oder ist das OK?
Kann man die Daten der zwei MPP getrennt ausgeben?
-
@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 V100R001C00SPC150Lö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 -
@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.

Da habe ich die Meldung erhalten, dass der Controller zu viele anfragen bearbeiten musste.
Ich habe das Abfrageintervall nun auf 18Sek gesetzt.

Und hier mein überarbeiteter kompletter Flow:
Hat vielleicht jemand eine Idee, warum mein Dongle mit der "hohen" Abfragerate ein Problem hat und die anderen Teilnehmer im Forum wohl eher nicht?
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:

Die Abfrage triggert dann die zweite Abfrage

-
Register 37000-37125:

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:

Nur als Anregung bzw. Idee, wenn man den Overhead der Register-Anfragen reduzieren möchte. ;-)
Gruß,
Mat -
-
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:

Die Abfrage triggert dann die zweite Abfrage

-
Register 37000-37125:

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:

Nur als Anregung bzw. Idee, wenn man den Overhead der Register-Anfragen reduzieren möchte. ;-)
Gruß,
Mat@madmat17
Das klingt spannend. Kannst du deinen Flow Mal Posten? Danke Dir! -
-
@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 V100R001C00SPC150Lö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@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:
-
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
-
@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:
-
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):

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:

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.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

mfg
@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):

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:

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.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

mfg
-
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
@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. ;)
