NEWS
JK-BMS über RS485 mit ESPHome auslesen
-
@marco-3 In der Vergangenheit war der Bluetooth-Stack aus dem Arduino-Framework kaputt/instabiler, als wenn man unmittelbar auf ESP-IDF setzt. Konkreter gesprochen: Das JK-BMS sendet 150 Bytes lange Notifications, welche wenn ich mich richtig erinnere so im BLE-Spec nicht vorgesehen sind. Das Arduino-Framework crasht beim Empfang einer solchen Nachricht. Der Kern unten drunter (ESP-IDF) steckt diese große Nachricht einfach weg. Es ist aber möglich, dass es sich um eine Problematik aus der Vergangenheit handelt, da es mittlerweile auch Nutzer gibt die aktiv das Arduino-Framework nutzen. Wenn du mich fragst, dann ist ESP-IDF der puristischere und stabilere Weg.
-
@syssi
Danke, sehr viel herraus genommen.
nur bei number meckert es beim komplieren
immer wenn ich dennumber:
Bereich lösche.
|-- ArduinoJson @ 6.18.5 *** [.pioenvs/bms1/src/esphome/components/jk_bms_ble/number/jk_number.o] Source `src/esphome/components/jk_bms_ble/number/jk_number.cpp' not found, needed by target `.pioenvs/bms1/src/esphome/components/jk_bms_ble/number/jk_number.o'.
-
Ein Clean-Build wird das Problem lösen:
~/.local/bin/esphome clean esp32-ble-example.yaml ~/.local/bin/esphome run esp32-ble-example.yaml
-
@syssi
Danke, hat es!!
Zum Glück gibt es den Klick Button beim Home Assistant. -
Kleine Rückmeldung. ESP liefert seit gestern Abend erfolgreich die Daten des JKBMS.
Und natürlich wieder eine Frage.
Kann man den Update Intervall irgend wo einstellen? Gefühlt kommen aller 2sekunden Daten rein.
-
Das JK-BMS publiziert seine Messwerte einmal pro Sekunde. Man kann sich daraufhin entscheiden, wieviel man davon verwirft:
jk_bms_ble: - ble_client_id: client0 protocol_version: ${protocol_version} throttle: 30s id: bms0
Per
throttle: 60s
wird nun ein Schwung Nachrichten pro Minute decodiert und per MQTT weitergereicht. Sobald alles läuft, solltest du das Log-Level herunterstellen damit der ESP nicht so sehr damit beschaeftigt ist Logs zu schreiben:logger: level: INFO
-
Ich weis ja nicht ob sie es schon wußten
Man kann das JKBMS mittlerweile mit der openDTU onbattery ( per Draht ) auslesen und es gibt eine openDTU Fusion Platine fertig bestückt die nach Einrichtung fast out of the box läuft.
Software ist OpenSource, Platine liegt je nach gewünschter Ausführung bei ca. 35 -45@. Und NEIN, ich bin weder Entwickler noch verdiene ich was dran. Ich denke der eine oder andere sucht eine einfache funktionierende Lösung ohne selbst Software kompilieren zu müssen oder zu löten. Bei Fragen könnt ihr mich gerne fragen oder direkt auf die Github Seite der Entwickler gehen.
Hab ich jetzt seit 2 Monaten problemlos im Einsatz. Derzeit wird die Software vom Entwickler bei Github noch erweitert um grundlegende Befehle zu senden ( Charge on/off etc. ). -
@nettworker
Klingt grundsätzlich interessant. Auch wenn bei meinem System die RS485 mit einem galvanisch getrennten Umwandler die Daten an Victron cerbo gehen.
Möchten ich den Cerbo nicht noch mehr belasten mit MQTT, mit Modbus sendet er schon die Ladekontroller Zustände.... Aber leider vom JK, sieht es spärlich mit Daten für Modbus aus.Daher nehme ich gern die Daten die vom JK kommen über BT ab. Das Victron System soll seine Arbeit machen.
Aber die Open DTU Fusion Lösung ist auch wieder ein Weg der nach Rom führt.
Danke für die Info. -
@syssi
Da klingt sehr interessant. Heißt das jetzt, daß die Messwerte aktuell mit 30sec oder 60sec versetzt an den iobroker kommen -
Da klingt sehr interessant. Heißt das jetzt, daß die Messwerte aktuell mit 30sec oder 60sec versetzt an den iobroker kommen
Schau Mal in deiner YAML, was dort aktuell eingestellt ist. Ich gehe von
5s
aus. Von einem Versatz würde ich nicht sprechen. Eine Nachricht vom BMS enthält alle Messwerte. Pro Sekunde wird eine Nachricht übertragen. Bei eine 5 Sekunden-Drosselung, werden 4 Nachrichten verworfen und jede 5. Nachricht verarbeitet. Das hat zur Folge, dass es alle 5 Sekunden (die gerade aktuelle Nachricht) auf dem MQTT-Broker ankommt. Im Fall der 60s werden 59 Nachrichten verworfen und die 60. propagiert. -
@syssi
O.k. ja, es stehen die 5 darin könnte ich da auch 1s eintragen?jk_bms_ble: - ble_client_id: client0 protocol_version: ${protocol_version} throttle: 5s // Abrufintervall der BMS Datensätze id: bms0
Darf man im yaml File Kommentare mit // eintragen, sie he wie im Beispiel
-
@marco-3 said in JK-BMS über RS485 mit ESPHome auslesen:
jk_bms_ble:
- ble_client_id: client0
protocol_version: ${protocol_version}
throttle: 5s // Abrufintervall der BMS Datensätze
id: bms0
Ja, das Zeichen dafür ist aber ein
#
:jk_bms_ble: - ble_client_id: client0 protocol_version: ${protocol_version} throttle: 5s # Abrufintervall der BMS Datensätze id: bms0
Auch möglich ist:
jk_bms_ble: - ble_client_id: client0 protocol_version: ${protocol_version} # Abrufintervall der BMS Datensätze throttle: 5s id: bms0
- ble_client_id: client0
-
Es läuft immer besser! Daten im 1s Takt kommen sehr zuverlässig.
Und schon ist die nächste Frage da.
Ich verwende w verschiedene ESP32 Boards. Ein normales und eine D1 Mini Version. Das normal hat eine Status LED, welche Blinkzeichen von sich gibt, sieht so aus, als ob es immer der MQTT Sendebefehl ist. Das D1 Board hat 2 Led, die erste ist für die Power ON. Bei der 2. Led steht ein L, diese gibt aber keine Status von sich. Kann man dies noch aktivieren, oder muss ich am Pinout noch eine irgend wo anbauen. -
In der YAML ist keine Anweisung enthalten, dass die LED gesteuert werden soll. Die Erklärung wird vielmehr sein: Eines der Boards besitzt eine TX-LED, welche leuchtet sobald Daten auf der seriellen Schnittstelle (GPIO1?) rausgeschrieben werden. Wenn du das Board über das Kabel flashst sollte sie flackern. Da der
logger
von ESPHome periodisch die Nachrichten auf die serielle Schnittstelle schreibt, leuchtet die LED im gleichen Takt.Wir können die YAML-Konfiguration beliebig erweitern und mit einer Anweisung versehen, was mit der LED (an
GPIO2
des D1 Mini ESP32) passieren soll. -
@syssi
Danke, was wäre, die sinnvollste Lösung beim D1?Ich möchte eigentlich bei einem Blick drauf nur erkennen, daß es läuft und nicht fest gefahren ist.
Oder kann man daß so weiter stricken...
Kein W-Lan --> 2x blinken 5sec Pause
Keine BT Verbindung --> 5x blinken 5sec Pause.Am Ende wäre es Klasse, wenn man mit einem Blick sieht ESP ist o.k. Fehler liegt bei Iobroker ...
Durch die andere ESP Version für das JKBMS, hab es in 1-30Tagen Abständen Aufhänger des ESP. Wobei ich nicht gleich wusste was los war. Vermutung lang bei, fest gefahren.
Daher hab ich mich hier für dies Lösung entschieden, weil diese weiter entwickelt wird. Und nun erst Recht, da die ganzen Tips und Vorschläge von dir, meine Probierfreude fördern und ich nicht gefrustet hinwerfe... Noch mal ganz großes Lob für die Hilfe und die JKBMS Implementierung auf esphome Basis hier.
-
@marco-3 Für WiFi/MQTT kannst du diesen Schnippsel nutzen:
status_led: pin: number: GPIO2 inverted: true
Hier findest du eine Beschreibung, was er tut: https://esphome.io/components/status_led.html
Für Bluetooth solltest du dir einen Lötkolben schnappen und eine weitere LED an einen freien GPIO löten. Vorzugsweise eine Blaue. Daraufhin werde ich dir zeigen, wie man sich an den
on_connect
undon_disconnect
-Callback desble_client
haengt, so dass man die LED an bzw. ausschaltet, sobald die Verbindung zum BMS steht/abbricht. (https://esphome.io/components/ble_client.html#on-connect) -
@syssi
Moin, eigentlich schwebt mir GPIO0 vor, da er gleich neben GND liegt. Aber laut Legende soll dieser nicht benutz werden. -
Gut erkannt. Bitte umschiffen. Wenn du
GPIO0
versehentlich (permant) auf Masse ziehst, dann bootet der ESP in Zukunft nur noch in den "Schreibe jetzt bitte neue Software drauf"-Modus anstatt die Anwendung zu starten. -
@syssi
GPIO27 wird es werden, passt auch super, GND gleich da und rechts oben, als BT Led gut geeignet.... -
Bitte den (bisher nicht erwähnten) Widerstand vergessen: https://techexplorations.com/guides/esp32/begin/digitalout/