NEWS
Mqtt - Variablen
-
@humidor sagte in Mqtt - Variablen:
der Client muss zyklisch am Broker subcriben, sonst ist nach 60s Schluss
Nein, das ist ein Publish. Steht auch da:
To activate keep-alive, send a read request to R/<portal ID>/keepalive. The payload may be blank
Also brauchst Du eine Publish-Node und keine Subscribe-Node! Die nennen ihre Topics halt so (Ein Publish auf
R/
ist eine "Read-Request" - das hat mit dem MQTT-Standard aber nichts zu tun. Da kennt man den Begriff "read" gar nicht.)@humidor sagte in Mqtt - Variablen:
wie ich oben schon geschrieben habe, der Node Red am Cerbo ist ein Client
Richtig. Habe nichts anderes gesagt. Genau wie dein MQTT-Adapter nur ein Client ist.
@humidor sagte in Mqtt - Variablen:
wird diese im ioBroker Mqtt Master erzeugt.
Nein. Nur wenn das Retain-Flag gesetzt wird sind die Payloads auf Topics persistent. Da wird nichts erzeugt. Das ist wie eine Broadcast-Nachricht. Alle, die abonniert haben, bekommen die Nachricht. Wer erst später abonniert, bekommt diese nicht (außer das Retain-Flag wurde beim publish gesetzt).
Es gibt in MQTT keine "Variablen"
@humidor sagte in Mqtt - Variablen:
der neue flashMQ soll ja in der neuen FW vom Cerbo drin sein
Richtig, hat Mosquitto abgelöst. Tut aber nichts zur Sache und verhält sich gleich.
-
@haus-automatisierung gut, dh zwischen Mqtt Standard und Victron ist ein Unterschied, das wird mich da wohl auch verwirren. Damit umschreibe ich ab jetzt nur noch. (lesen/holen/schreiben)
ich sage dem ioBroker Broker, er soll bitte seine Daten senden
ich mache das zyklisch alle 30s, sonst sendet er nach 60s nicht mehr.
das wird im Cerbo Node Red mit einer Mqtt Out Node gemacht
auf Mqtt In Node bekomme ich die Werte, die ich sehen will. -
@humidor Am Ende weiß ich nicht genau, was Du vor hast.
- Du hast einen MQTT-Broker (der läuft auf dem Cerbo).
- Dieser erwartet von einem Client (z.B. Node-RED auf dem Cerbo) einen regelmäßig "Read-Request".
- Dieser "Read-Request" ist aber eigentlich nur ein Publish auf
R/<portal ID>/keepalive
. Das braucht also in Node-RED eine MQTT-Out-Node. Payload kann auch leer sein. Also total egal. Zyklisch senden geht z.B. mit einer Inject Node.
Jetzt ist die Frage, welche Rolle der ioBroker dabei spielt.
- Warum verbindet der sich nicht auch einfach mit dem MQTT-Adapter (im Client-Modus) gegen den MQTT-Broker im Cerbo?
- Was genau soll der ioBroker dann tun?
Um nochmal auf die Ausgangsfragen einzugehen:
@humidor sagte in Mqtt - Variablen:
kann ich aus dem Blockly Variablen im Mqtt Master (am Victron Cerbo) erzeugen?
Diese "Variablen" heißen Topics und sind nicht persistent. Um einen Datenpunkt im ioBroker zu erzeugen, muss einfach nur eine Nachricht auf einem abonnierten Topic gepublished werden. Dann wird diese automatisch angelegt.
Ein schreiben dieser Datenpunkte führt dann wieder zu einem Publish auf dem Topic (dies ist auf dem Objekt in ioBroker hinterlegt).
@humidor sagte in Mqtt - Variablen:
Was ich nun will, ist die Regelung / Steuerung vom ioBroker mittels Blockly zu realisieren
Am Ende schreibst Du damit einfach nur Datenpunkte. Wie jeden anderen Datenpunkt auch. Und der MQTT-Adapter macht aus diesem "steuere"-Befehl dann ein Publish auf MQTT.
Wie genau was verknüpft werden soll, welche Rolle Node-RED und welche ioBroker spielt, habe ich nach wie vor nicht verstanden und müsste genauer definiert werden.
-
Achso und es gibt noch einen MQTT-Cloud-Server, gegen welchen man sich auch verbinden könnte. Daher kommt scheinbar auch Deine Dokumentation. Dafür arbeitet der MQTT-Broker auf dem Cerbo als Relay und gibt alles an den Cloud-Server weiter.
Willst Du das wirklich über den MQTT-Broker in der Cloud machen? Sind das verschiedene Standorte? Oder warum nicht den lokalen MQTT-Broker des Cerbo nutzen?
Ich hatte die kompletten Zusammenhänge bei VenusOS und dem VRM mal hier dokumentiert: https://www.youtube.com/watch?v=QTDAZXycTlk
-
@haus-automatisierung nein, keine Cloud im Spiel.
in den Mqtt Out Nodes am Cerbo Node Red ist IP:Port hinterlegt, dh der Node kommuniziert hier nicht mit dem Cerbo Broker, sondern direkt mit dem ioBroker Broker.
so habe ich es verstanden.
Wenn der Cerbo Node Red Client mit dem Cerbo Broker kommunizieren soll, muss die lokale IP/hostname/127.xxxx hinterlegt sein.Bsp. Bilder zu einem anderen Cerbo
der ioBroker mqtt.0 Broker zeigt diese an, die am Cerbo mit dem Mqtt out ..
mqtt.1 Client ist ein Cerbo und mqtt.2 Client ist ein Cerbo
im Node-Red vom ioBroker wird auf diese Cerbo Broker ein request gesendet
die Topics sind dann im ioBroker Objektbaum aufgelistet -
@humidor sagte in Mqtt - Variablen:
dh der Node kommuniziert hier nicht mit dem Cerbo Broker, sondern direkt mit dem ioBroker Broker.
Also nutzt du Node-RED als "Middleware" zwischen dem MQTT-Broker vom Cerbo und dem MQTT-Broker von ioBroker? Du zeigst ja immer nur Ausschnitte von Flows. Und die Fragen oben werden auch nicht beantwortet. Skizzier das gerne mal, schildere was wo genau konfiguriert ist und dann kann ich helfen.
-
@humidor sagte in Mqtt - Variablen:
der ioBroker mqtt.0 Broker zeigt diese an, die am Cerbo mit dem Mqtt out ..
mqtt.1 Client ist ein Cerbo und mqtt.2 Client ist ein Cerbo
im Node-Red vom ioBroker wird auf diese Cerbo Broker ein request gesendetUnd wozu das Ganze? Ich würde mich für Node-RED oder ioBroker entscheiden. Wenn mqtt.1 und mqtt.2 doch alles bereits abonnieren und an alle Daten kommen, warum dann nochmal einen MQTT-Broker (mqtt.0) betreiben und diesen irgendwie aus Node-RED mit den gleichen Daten füttern?!
-
@haus-automatisierung ich beantworte dir alle Fragen, dazu muss ich aber genau wissen was du sehen möchtest.
Aufgabe:
- ioBroker = Steuerung der Regelung, schickt die Werte an den Cerbo BAT, der diese an die Endgeräte (3xMultiplus im ESS) weitergibt
- ioBroker Clients verbinden sich auf 2 Cerbos (ESS/BAT) um die Daten von den Clients zu sehen
- ioBroker kann nicht! auf alle Parameter der am Cerbo angeschlossenen Geräte zugreifen, das kann nur der Cerbo
- der Cerbo dient dazu die Kommunikation und die übergebenen Parameter zu übergeben bzw. zu überwachen
wer nun Client und Broker ist, ist mir klar, wie die Kommunikation zwischen den Teilnehmern exakt abläuft, anscheinend nicht.
-
@humidor sagte in Mqtt - Variablen:
ioBroker Clients verbinden sich auf 2 Cerbos (ESS/BAT) um die Daten von den Clients zu sehen
Und warum nutzt Du diese Clients nicht auch um ein Publish durchzuführen und die gewünschten Einstellungen zu setzen? Verstehe nach wie vor die Rolle von dem MQTT-Broker in ioBroker (mqtt.0) nicht.
-
@haus-automatisierung
das war auch falsch, die ioBroker Clients requesten beim Cerbo Broker und ich kann im ioBroker die Werte sehe und verwenden, reine Information.die Frage die du stellst, ist die selbe die ich stelle
wie übergebe ich vom ioBroker die Werte und Steuerbefehler an den Cerbo. -
@humidor sagte in Mqtt - Variablen:
wie übergebe ich vom ioBroker die Werte und Steuerbefehler an den Cerbo.
Gibt viele Wege.
- Entweder Du abonnierst alle Topics in der Instanzkonfiguration von mqtt.1 und mqtt.2 und publishst dann einmalig mit einem anderen Client (z.B. Node-RED oder MQTT-Explorer) eine Nachricht damit der Datenpunkt angelegt wird
- oder Du nimmst den Blockly-Baustein für ein Publish auf einem Topic (falls dieses auch abonniert ist, wird dafür auch ein Datenpunkt angelegt).
- oder Du legst das Objekt manuell in der Struktur an (Expertenmodus) und setzt das Topic im native-Attribut richtig (auf das gewünschte Topic).
-
@haus-automatisierung
spielen wir bitte mal den 1. Punkt durch.
Instanzkonfiguration, lege ich dazu in dessen Settings etwas an?
"#" . bedeutet alles, aber allein mit diesen Einstellungen bekomme ich nichts im ObjektbaumioB.mqtt.1 Client für Cerbo ESS
- erst durch einen zyklischen request am Cerbo Broker, wird der vollständige Objektbau unter N/... angelegt (Victron docu)
(muss jetzt kurz 2h weg)
- erst durch einen zyklischen request am Cerbo Broker, wird der vollständige Objektbau unter N/... angelegt (Victron docu)
-
@humidor sagte in Mqtt - Variablen:
"#" . bedeutet alles, aber allein mit diesen Einstellungen bekomme ich nichts im Objektbaum
Richtig, das war ja nur Teil 1 (subscribe). Jetzt fehlt Dir ein Publish. Wie lautet denn das Topic welches Du schreiben möchtest?
-
@haus-automatisierung meinst du den request, dass ich den Objektbaum bekomme oder das Topic auf das ich meine Regelungs/Steuerwerte schreibe?
-
@humidor Das MQTT-Topic, welches Du gerade publishen willst aus ioBroker heraus
-
@haus-automatisierung du meinst das, vermute ich:
das sind die Werte/Topics die ich aus dem ioBroker beschreibe, der Cerbo NodeRed Client liest diese ein und reicht sie nach überprüfung weiter -
@haus-automatisierung nimma da??
-
@humidor Ne, ich werde hier nicht verstanden....
- Dir fehlen Werte im Objektbaum
- Du fragst wie man diese anlegt
- Ich zeige drei Möglichkeiten auf
- Du teilst einen Screenshot von Werten, welche gar nicht da sein können(?), weil Du ja wissen wolltest, wie man diese anlegt
- ???
Nochmal: Auf welches MQTT-Topic (zu welchem Dir ja im ioBroker ein State fehlt), willst Du in Zukunft etwas aus dem ioBroker heraus schreiben?
-
@haus-automatisierung ich verstehe nur Bahnhof...
sagte, Punkt 1 (von 3) möchte ich näher ansehen,
du fragst mich nach den Werten die ich aus ioBroker beschreiben will
das sind die Werte, egal wie die jetzt formatiert sind oder wo sie liegen, das sind die Werte.
das nächste ist, wo lege ich die Topics an.ich will nicht, dass über meinen ioBroker Broker gegangen wird
dh es müssten im Cerbo Bat Mqtt Master die Topics angelegt werden, die ich dann beschreiben will, so mein Verständnis.ich verstehe diesen Satz nicht:
Nochmal: Auf welches MQTT-Topic (zu welchem Dir ja im ioBroker ein State fehlt), willst Du in Zukunft etwas aus dem ioBroker heraus schreiben?wenn das heißen soll, ich soll das Topic nennen, das am Cerbo Bat Broker liegt und ich es aus dem ioBroker beschreiben will - kann ich nur antworten - das gibt es noch nicht.
-
@humidor sagte in Mqtt - Variablen:
wenn das heißen soll, ich soll das Topic nennen, das am Cerbo Bat Broker liegt und ich es aus dem ioBroker beschreiben will - kann ich nur antworten - das gibt es noch nicht.
Im MQTT-Broker? Da muss man keine Topics anlegen oder Registrieren. Wie schon öfter geschrieben. Einfach senden (publish) und wer etwas hören will (subscribe) macht damit etwas.
Also musst Du schon wissen, auf welche Topics die andere Seite genau hört. Da wird ja nie etwas aktiv gesendet und automatisch angelegt, weil eben nur gehört wird, ...
Daher musst Du das Topic kennen und manuell etwas aus einem Client deiner Wahl (siehe oben) publishen.
Das war erstmal meine letzte Antwort. Wie gesagt, ich habe dazu schon viel gezeigt und alles im Detail erklärt. Wenn Dir in den Inhalten etwas fehlen sollten, einfach melden.