Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • 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

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. ioBroker Allgemein
  4. Verfügbarkeit von Sensoren über Node Red überwachen

NEWS

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    18
    1
    720

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    18
    1
    5.9k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.5k

Verfügbarkeit von Sensoren über Node Red überwachen

Scheduled Pinned Locked Moved ioBroker Allgemein
426 Posts 5 Posters 65.0k Views 4 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • S Offline
    S Offline
    Schmetterfliege
    wrote on last edited by
    #231

    aaaaaah, habs verstanden.
    Nach der Function Node holst du dir alle Werte, splittest die dann und berechnest jeweils.

    Sorry!

    mickymM 1 Reply Last reply
    0
    • S Schmetterfliege

      aaaaaah, habs verstanden.
      Nach der Function Node holst du dir alle Werte, splittest die dann und berechnest jeweils.

      Sorry!

      mickymM Offline
      mickymM Offline
      mickym
      Most Active
      wrote on last edited by mickym
      #232

      @schmetterfliege Der Kandidat hat 100 Punkte. 👍

      Wie gesagt, so verbraucht das am wenigsten Ressourcen. Wenn Du unbedingt regelmäßige Updates haben willst. dann siehst Du eine Inject Node als trigger im Flow- die kannst Du natürlich auch periodisch triggern lassen und Du hast zusätzlich in best. Zeitabständen Updates.

      Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

      1 Reply Last reply
      0
      • S Offline
        S Offline
        Schmetterfliege
        wrote on last edited by
        #233

        @mickym

        ich versuche ja gar nicht das periodisch zu machen. Sondern so wie du, dass er die Zeiten updatet wenn irgendein Gerät neue Daten liefert.
        Bin aber gerade irgendwie am scheitern an den Timestamps...
        Ich möchte die Timestamps nehmen die das System bzw. der Adapter mir sowieso liefert.
        Aber aus irgendeinem Grund kommt da bei sau vielen Geräten "vor 3 Tagen" raus.. bin grade noch am probieren

        mickymM 1 Reply Last reply
        0
        • S Schmetterfliege

          @mickym

          ich versuche ja gar nicht das periodisch zu machen. Sondern so wie du, dass er die Zeiten updatet wenn irgendein Gerät neue Daten liefert.
          Bin aber gerade irgendwie am scheitern an den Timestamps...
          Ich möchte die Timestamps nehmen die das System bzw. der Adapter mir sowieso liefert.
          Aber aus irgendeinem Grund kommt da bei sau vielen Geräten "vor 3 Tagen" raus.. bin grade noch am probieren

          mickymM Offline
          mickymM Offline
          mickym
          Most Active
          wrote on last edited by mickym
          #234

          @schmetterfliege Wie gesagt - ich finde das mit Timestamps auslesen überflüssig - ich fange halt von vorne an - wenn der NR Adapter startet. Wenn Du es wirklich so genau haben willst, dann musst Du die Timestamps ja nur zum Initialisieren der Objekte auslesen. Dann musst halt sehen, ob die richtigen Moments gebildet werden - wenn Du ein debug Node anhängst - dann siehst Du ja was für ein Datum rauskommt. Ich halte das wie gesagt für überflüssigen Aufwand, da sich alle Geräte innerhalb von 2 Stunden sowieso melden. Ansonsten schau Dir mal meinen Thread an - wo ich die moments Bibliothek ausgiebig getestet und erläutert habe. Was interessieren mich Timestamps vom Adapter, wenn ich selbst direkt ermittle, wann sich ein Gerät meldet.

          https://forum.iobroker.net/topic/50086/datum-und-zeitverarbeitung-mit-nodered

          Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

          S 1 Reply Last reply
          0
          • mickymM mickym

            @schmetterfliege Wie gesagt - ich finde das mit Timestamps auslesen überflüssig - ich fange halt von vorne an - wenn der NR Adapter startet. Wenn Du es wirklich so genau haben willst, dann musst Du die Timestamps ja nur zum Initialisieren der Objekte auslesen. Dann musst halt sehen, ob die richtigen Moments gebildet werden - wenn Du ein debug Node anhängst - dann siehst Du ja was für ein Datum rauskommt. Ich halte das wie gesagt für überflüssigen Aufwand, da sich alle Geräte innerhalb von 2 Stunden sowieso melden. Ansonsten schau Dir mal meinen Thread an - wo ich die moments Bibliothek ausgiebig getestet und erläutert habe. Was interessieren mich Timestamps vom Adapter, wenn ich selbst direkt ermittle, wann sich ein Gerät meldet.

            https://forum.iobroker.net/topic/50086/datum-und-zeitverarbeitung-mit-nodered

            S Offline
            S Offline
            Schmetterfliege
            wrote on last edited by Schmetterfliege
            #235

            @mickym said in Verfügbarkeit von Sensoren über Node Red überwachen:

            @schmetterfliege Wie gesagt - ich finde das mit Timestamps auslesen überflüssig - ich fange halt von vorne an - wenn der NR Adapter startet. Wenn Du es wirklich so genau haben willst, dann musst Du die Timestamps ja nur zum Initialisieren der Objekte auslesen. Dann musst halt sehen, ob die richtigen Moments gebildet werden - wenn Du ein debug Node anhängst - dann siehst Du ja was für ein Datum rauskommt. Ich halte das wie gesagt für überflüssigen Aufwand, da sich alle Geräte innerhalb von 2 Stunden sowieso melden. Ansonsten schau Dir mal meinen Thread an - wo ich die moments Bibliothek ausgiebig getestet und erläutert habe. Was interessieren mich Timestamps vom Adapter, wenn ich selbst direkt ermittle, wann sich ein Gerät meldet.

            https://forum.iobroker.net/topic/50086/datum-und-zeitverarbeitung-mit-nodered

            Wäre dann der nächste Step, sobald meine Geräte zuverlässig funktionieren. Da sind durchaus Geräte dabei die eben nicht alle 2 Stunden schreien. Teilweise sind auch Geräte dabei die noch in Kartons verpackt sind und noch nicht wieder eingesetzt wurden.
            Solange ich nicht sicher sein kann dass alle Geräte zuverlässig sind, möchte ich ungern Timestamps nehmen die beim Absturz von NR weg sind.

            Hänge aber gerade ein wenig fest und verstehe nicht wieso.
            Meinen Fehler wegen den 3 Tagen habe ich gefunden, ich hatte an einer vorherigen Stelle im Flow das abspeichern der Timestamps verhauen, weshalb diese nicht mehr geupdated wurden und deshalb 3 Tage rauskamen.
            Das hab ich jetzt soweit gefixt, aber:

            [
                {
                    "id": "7fe74e1c4f96ebec",
                    "type": "change",
                    "z": "1090acf7.2d6813",
                    "name": "",
                    "rules": [
                        {
                            "t": "set",
                            "p": "payload",
                            "pt": "msg",
                            "to": "$moment(payload.timestamp).locale('de').fromNow()",
                            "tot": "jsonata"
                        }
                    ],
                    "action": "",
                    "property": "",
                    "from": "",
                    "to": "",
                    "reg": false,
                    "x": 1450,
                    "y": 1980,
                    "wires": [
                        [
                            "a06c0fd115f037d5"
                        ]
                    ]
                },
                {
                    "id": "a06c0fd115f037d5",
                    "type": "function",
                    "z": "1090acf7.2d6813",
                    "name": "Zeitstempel in fState",
                    "func": "flow.set ('zigbee.' + msg.topic + '.lastupdate', msg.payload);\nreturn msg;",
                    "outputs": 1,
                    "noerr": 0,
                    "initialize": "",
                    "finalize": "",
                    "libs": [],
                    "x": 1660,
                    "y": 1980,
                    "wires": [
                        []
                    ]
                }
            ]
            

            Der Teil berechnet mir die Differenzen. Ich hole alle gespeicherten Werte vom Flow (in der Change Node vor split -> Join relativ am Ende) und berechne dann pro Topic die Differenz und speicher sie wieder ab. Das funktioniert soweit auch. Aber ich check nicht an welche Stelle vom gesamten Flow ich das packen muss.
            Mache ich das direkt vor die Funktion die meine Tabelle zusammenbaut, bleibt die Tabelle leer. Obwohl die Funktion ja keine Daten von irgendwelchen Payloads übernimmt, sondern sich alles aus dem Flow holt.

            So sieht der Flow aus ohne die Berechnung der Differenz:
            e78907f0-4190-4f66-b609-3e17e6d6bfae-image.png
            ja, is hässlich - aber funktioniert 😁

            mickymM 1 Reply Last reply
            0
            • S Offline
              S Offline
              Schmetterfliege
              wrote on last edited by Schmetterfliege
              #236

              Nevermind, die letzte Function Node holt sich das Zeug gar nicht aus dem Flow, sondern aus jener change Node...

              Habs, muss vor dem Zusammenbau der Tabelle nochmal den gesamten Flow holen, splitten und wieder joinen.
              Wenn ich das nicht mache, updatet die Tabelle nicht.
              D.h. Payload direkt übergeben geht nicht, Payload splitten und wieder zusammenfügen aber schon? Übersteigt gerade meinen Horizont^^

              1 Reply Last reply
              0
              • S Schmetterfliege

                @mickym said in Verfügbarkeit von Sensoren über Node Red überwachen:

                @schmetterfliege Wie gesagt - ich finde das mit Timestamps auslesen überflüssig - ich fange halt von vorne an - wenn der NR Adapter startet. Wenn Du es wirklich so genau haben willst, dann musst Du die Timestamps ja nur zum Initialisieren der Objekte auslesen. Dann musst halt sehen, ob die richtigen Moments gebildet werden - wenn Du ein debug Node anhängst - dann siehst Du ja was für ein Datum rauskommt. Ich halte das wie gesagt für überflüssigen Aufwand, da sich alle Geräte innerhalb von 2 Stunden sowieso melden. Ansonsten schau Dir mal meinen Thread an - wo ich die moments Bibliothek ausgiebig getestet und erläutert habe. Was interessieren mich Timestamps vom Adapter, wenn ich selbst direkt ermittle, wann sich ein Gerät meldet.

                https://forum.iobroker.net/topic/50086/datum-und-zeitverarbeitung-mit-nodered

                Wäre dann der nächste Step, sobald meine Geräte zuverlässig funktionieren. Da sind durchaus Geräte dabei die eben nicht alle 2 Stunden schreien. Teilweise sind auch Geräte dabei die noch in Kartons verpackt sind und noch nicht wieder eingesetzt wurden.
                Solange ich nicht sicher sein kann dass alle Geräte zuverlässig sind, möchte ich ungern Timestamps nehmen die beim Absturz von NR weg sind.

                Hänge aber gerade ein wenig fest und verstehe nicht wieso.
                Meinen Fehler wegen den 3 Tagen habe ich gefunden, ich hatte an einer vorherigen Stelle im Flow das abspeichern der Timestamps verhauen, weshalb diese nicht mehr geupdated wurden und deshalb 3 Tage rauskamen.
                Das hab ich jetzt soweit gefixt, aber:

                [
                    {
                        "id": "7fe74e1c4f96ebec",
                        "type": "change",
                        "z": "1090acf7.2d6813",
                        "name": "",
                        "rules": [
                            {
                                "t": "set",
                                "p": "payload",
                                "pt": "msg",
                                "to": "$moment(payload.timestamp).locale('de').fromNow()",
                                "tot": "jsonata"
                            }
                        ],
                        "action": "",
                        "property": "",
                        "from": "",
                        "to": "",
                        "reg": false,
                        "x": 1450,
                        "y": 1980,
                        "wires": [
                            [
                                "a06c0fd115f037d5"
                            ]
                        ]
                    },
                    {
                        "id": "a06c0fd115f037d5",
                        "type": "function",
                        "z": "1090acf7.2d6813",
                        "name": "Zeitstempel in fState",
                        "func": "flow.set ('zigbee.' + msg.topic + '.lastupdate', msg.payload);\nreturn msg;",
                        "outputs": 1,
                        "noerr": 0,
                        "initialize": "",
                        "finalize": "",
                        "libs": [],
                        "x": 1660,
                        "y": 1980,
                        "wires": [
                            []
                        ]
                    }
                ]
                

                Der Teil berechnet mir die Differenzen. Ich hole alle gespeicherten Werte vom Flow (in der Change Node vor split -> Join relativ am Ende) und berechne dann pro Topic die Differenz und speicher sie wieder ab. Das funktioniert soweit auch. Aber ich check nicht an welche Stelle vom gesamten Flow ich das packen muss.
                Mache ich das direkt vor die Funktion die meine Tabelle zusammenbaut, bleibt die Tabelle leer. Obwohl die Funktion ja keine Daten von irgendwelchen Payloads übernimmt, sondern sich alles aus dem Flow holt.

                So sieht der Flow aus ohne die Berechnung der Differenz:
                e78907f0-4190-4f66-b609-3e17e6d6bfae-image.png
                ja, is hässlich - aber funktioniert 😁

                mickymM Offline
                mickymM Offline
                mickym
                Most Active
                wrote on last edited by mickym
                #237

                @schmetterfliege Ich kann mich so noch dunkel daran erinnern. In dem Fall - wenn Du es unbedingt in Deiner Tabelle haben willst, dann müsste man die Daten einbauen, bevor das Array gebildet wird - also vor der letzten JOIN Node. Wahrscheinlich würde ich keinen extra Flow machen - sondern über eine Call Node - den Zeitermittlungsflow einzubauen. Dadurch dass wir aber über die Kontextvariable die Eigenschaft des topics zu verwenden, dann musst halt die Zeitdifferenz nach der split Node einzeln ermitteln.

                Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                S 2 Replies Last reply
                0
                • mickymM mickym

                  @schmetterfliege Ich kann mich so noch dunkel daran erinnern. In dem Fall - wenn Du es unbedingt in Deiner Tabelle haben willst, dann müsste man die Daten einbauen, bevor das Array gebildet wird - also vor der letzten JOIN Node. Wahrscheinlich würde ich keinen extra Flow machen - sondern über eine Call Node - den Zeitermittlungsflow einzubauen. Dadurch dass wir aber über die Kontextvariable die Eigenschaft des topics zu verwenden, dann musst halt die Zeitdifferenz nach der split Node einzeln ermitteln.

                  S Offline
                  S Offline
                  Schmetterfliege
                  wrote on last edited by
                  #238

                  @mickym said in Verfügbarkeit von Sensoren über Node Red überwachen:

                  @schmetterfliege Ich kann mich so noch dunkel daran erinnern. In dem Fall - wenn Du es unbedingt in Deiner Tabelle haben willst, dann müsste man die Daten einbauen, bevor das Array gebildet wird - also vor der letzten JOIN Node. Wahrscheinlich würde ich keinen extra Flow machen - sondern über eine Call Node - den Zeitermittlungsflow einzubauen.

                  Ordnung reinbringen wäre dann einer der nächsten Steps, solange das noch nicht sauber läuft komme ich mit dem Chaos besser klar haha. Aber dürfte jetzt soweit eigentlich einen ordentlichen Stand haben bei dem ich jetzt anfangen kann Ordnung zu schaffen :)

                  mickymM 1 Reply Last reply
                  0
                  • mickymM mickym

                    @schmetterfliege Ich kann mich so noch dunkel daran erinnern. In dem Fall - wenn Du es unbedingt in Deiner Tabelle haben willst, dann müsste man die Daten einbauen, bevor das Array gebildet wird - also vor der letzten JOIN Node. Wahrscheinlich würde ich keinen extra Flow machen - sondern über eine Call Node - den Zeitermittlungsflow einzubauen. Dadurch dass wir aber über die Kontextvariable die Eigenschaft des topics zu verwenden, dann musst halt die Zeitdifferenz nach der split Node einzeln ermitteln.

                    S Offline
                    S Offline
                    Schmetterfliege
                    wrote on last edited by Schmetterfliege
                    #239

                    @mickym said in Verfügbarkeit von Sensoren über Node Red überwachen:

                    @schmetterfliege Ich kann mich so noch dunkel daran erinnern. In dem Fall - wenn Du es unbedingt in Deiner Tabelle haben willst, dann müsste man die Daten einbauen, bevor das Array gebildet wird - also vor der letzten JOIN Node. Wahrscheinlich würde ich keinen extra Flow machen - sondern über eine Call Node - den Zeitermittlungsflow einzubauen. Dadurch dass wir aber über die Kontextvariable die Eigenschaft des topics zu verwenden, dann musst halt die Zeitdifferenz nach der split Node einzeln ermitteln.

                    Auf einer Skala von 1-10, wie mies ist der Teil hier?
                    952ef957-0a4a-44a0-8ac7-7dcd26aa9360-image.png

                    Das wäre jetzt meine Lösung. Flowvariable holen, für jedes Gerät anhand des Timestamps die Zeitdifferenz berechnen und wieder im Flow speichern, dann nochmal die Flowvariablen holen, splitten und zusammenfüge (checke echt nicht why) und dann die Tabelle aufbauen.

                    EDIT: Glaube kann mir die Frage selbst beantworten.
                    Wenn ich nicht ganz doof bin, würde der für jedes Abspeichern (18 Geräte) nochmal die Flowvariable holen + splitten und dann zusammenfügen und die Tabelle erstellen.
                    Also für jedes Update mache ich dann doch 18 mal die Tabelle neu, oder?
                    Bräuchte eher eine Skala mit Minusbereich...

                    Wäre die Lösung nach dem Abspeichern noch ein JOIN dazwischen zu packen und eine Sekunde zu warten? Dann dürfte der danach doch nur 1 mal weitermachen statt 18 mal, oder?

                    mickymM 1 Reply Last reply
                    0
                    • S Schmetterfliege

                      @mickym said in Verfügbarkeit von Sensoren über Node Red überwachen:

                      @schmetterfliege Ich kann mich so noch dunkel daran erinnern. In dem Fall - wenn Du es unbedingt in Deiner Tabelle haben willst, dann müsste man die Daten einbauen, bevor das Array gebildet wird - also vor der letzten JOIN Node. Wahrscheinlich würde ich keinen extra Flow machen - sondern über eine Call Node - den Zeitermittlungsflow einzubauen.

                      Ordnung reinbringen wäre dann einer der nächsten Steps, solange das noch nicht sauber läuft komme ich mit dem Chaos besser klar haha. Aber dürfte jetzt soweit eigentlich einen ordentlichen Stand haben bei dem ich jetzt anfangen kann Ordnung zu schaffen :)

                      mickymM Offline
                      mickymM Offline
                      mickym
                      Most Active
                      wrote on last edited by
                      #240

                      @schmetterfliege Im Übrigen schau Dir halt die moments Bibliothek an und was ich in dem Thread geschrieben habe. Es gibt ja nicht nur fromNow(), sondern auch from - damit kann man dann auch die Differenz zwischen zwei beliebigen moment Objekte berechnen.

                      Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                      1 Reply Last reply
                      1
                      • S Schmetterfliege

                        @mickym said in Verfügbarkeit von Sensoren über Node Red überwachen:

                        @schmetterfliege Ich kann mich so noch dunkel daran erinnern. In dem Fall - wenn Du es unbedingt in Deiner Tabelle haben willst, dann müsste man die Daten einbauen, bevor das Array gebildet wird - also vor der letzten JOIN Node. Wahrscheinlich würde ich keinen extra Flow machen - sondern über eine Call Node - den Zeitermittlungsflow einzubauen. Dadurch dass wir aber über die Kontextvariable die Eigenschaft des topics zu verwenden, dann musst halt die Zeitdifferenz nach der split Node einzeln ermitteln.

                        Auf einer Skala von 1-10, wie mies ist der Teil hier?
                        952ef957-0a4a-44a0-8ac7-7dcd26aa9360-image.png

                        Das wäre jetzt meine Lösung. Flowvariable holen, für jedes Gerät anhand des Timestamps die Zeitdifferenz berechnen und wieder im Flow speichern, dann nochmal die Flowvariablen holen, splitten und zusammenfüge (checke echt nicht why) und dann die Tabelle aufbauen.

                        EDIT: Glaube kann mir die Frage selbst beantworten.
                        Wenn ich nicht ganz doof bin, würde der für jedes Abspeichern (18 Geräte) nochmal die Flowvariable holen + splitten und dann zusammenfügen und die Tabelle erstellen.
                        Also für jedes Update mache ich dann doch 18 mal die Tabelle neu, oder?
                        Bräuchte eher eine Skala mit Minusbereich...

                        Wäre die Lösung nach dem Abspeichern noch ein JOIN dazwischen zu packen und eine Sekunde zu warten? Dann dürfte der danach doch nur 1 mal weitermachen statt 18 mal, oder?

                        mickymM Offline
                        mickymM Offline
                        mickym
                        Most Active
                        wrote on last edited by
                        #241

                        @schmetterfliege Ehrlich gesagt - ist mein Geist zu müde - das Nachzuvollziehen. Wenn es funktioniert - dann machs. ;) - Ich hab in der Kürze auch kein Idee. Die Tabelle war schon eine Herausforderung und nun auch die Timestamps in die Tabelle aufzunehmen - habe ich ehrlich gesagt momentan keinen Plan und bin wie gesagt auch zu faul einen Plan zu machen.

                        Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                        S 1 Reply Last reply
                        0
                        • mickymM mickym

                          @schmetterfliege Ehrlich gesagt - ist mein Geist zu müde - das Nachzuvollziehen. Wenn es funktioniert - dann machs. ;) - Ich hab in der Kürze auch kein Idee. Die Tabelle war schon eine Herausforderung und nun auch die Timestamps in die Tabelle aufzunehmen - habe ich ehrlich gesagt momentan keinen Plan und bin wie gesagt auch zu faul einen Plan zu machen.

                          S Offline
                          S Offline
                          Schmetterfliege
                          wrote on last edited by
                          #242

                          @mickym said in Verfügbarkeit von Sensoren über Node Red überwachen:

                          @schmetterfliege Ehrlich gesagt - ist mein Geist zu müde - das Nachzuvollziehen. Wenn es funktioniert - dann machs. ;) - Ich hab in der Kürze auch kein Idee. Die Tabelle war schon eine Herausforderung und nun auch die Timestamps in die Tabelle aufzunehmen - habe ich ehrlich gesagt momentan keinen Plan und bin wie gesagt auch zu faul einen Plan zu machen.

                          Okidoki :)
                          Dann wünsche ich dir mal eine wunderbare Nacht und einen entspannten und erholenden Schlaf 😀

                          mickymM 1 Reply Last reply
                          0
                          • S Schmetterfliege

                            @mickym said in Verfügbarkeit von Sensoren über Node Red überwachen:

                            @schmetterfliege Ehrlich gesagt - ist mein Geist zu müde - das Nachzuvollziehen. Wenn es funktioniert - dann machs. ;) - Ich hab in der Kürze auch kein Idee. Die Tabelle war schon eine Herausforderung und nun auch die Timestamps in die Tabelle aufzunehmen - habe ich ehrlich gesagt momentan keinen Plan und bin wie gesagt auch zu faul einen Plan zu machen.

                            Okidoki :)
                            Dann wünsche ich dir mal eine wunderbare Nacht und einen entspannten und erholenden Schlaf 😀

                            mickymM Offline
                            mickymM Offline
                            mickym
                            Most Active
                            wrote on last edited by
                            #243

                            @schmetterfliege Nee in die Heia gehe ich noch nicht - ich bin schon noch da - aber keine Lust Flows zu machen - das heißt ja nicht, dass Du nicht kreativ sein kannst. Du kannst gerne einzelne Fragen stellen - aber nicht einen Flow, den ich beurteilen soll. ;)

                            Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                            S 1 Reply Last reply
                            0
                            • mickymM mickym

                              @schmetterfliege Nee in die Heia gehe ich noch nicht - ich bin schon noch da - aber keine Lust Flows zu machen - das heißt ja nicht, dass Du nicht kreativ sein kannst. Du kannst gerne einzelne Fragen stellen - aber nicht einen Flow, den ich beurteilen soll. ;)

                              S Offline
                              S Offline
                              Schmetterfliege
                              wrote on last edited by
                              #244

                              @mickym

                              Für mich war's aber Zeit 😁
                              Mein Schlafrythmus ist seit 2 Jahren eher... "ungesund" und nicht grade optimal für mein Arbeitsleben - den muss ich langsam mal in die richtige Richtung drücken hehe.

                              Ich stelle die Frage(n) nochmal und versuche keine komplette Flow-Analyse daraus zu machen 😀
                              In meinem Flow wird alles möglich in die Kontextvariablen gepackt, zum Ende dann alle Variablen geladen und damit die Tabelle gebastelt. Soweit so gut.
                              Um die Berechnung der Differenz zu machen muss ich ja auch den Kontext laden, die Berechnung machen und das dann wieder im Kontext speichern. Soweit auch so gut.

                              Im Flow muss das ja passieren nachdem ich alle anderen Daten gesammelt habe und bevor ich die Tabelle erstelle.
                              Deshalb mache ich die Berechnung direkt vor dem Erstellen der Tabelle.
                              Meine Fragen:

                              1. Um die Tabelle zu basteln muss ich vorher den Kontext in den Payload packen. Das alleine funktioniert aber nicht, sondern ich muss diesen Payload erst splitten und dann wieder joinen. -> Warum? Was für einen Unterschied macht es den Kontext zu übergeben vs. Kontext splitten dann wieder joinen und dann übergeben?
                              2. Das Berechnen der Differenzen triggert ja jedes mal die nächste Node, was dann den Kontext lädt (splittet und joint) und dann die Tabelle erstellt. Ich berechne 18 Differenzen, d.h. long story short: die Tabelle wird jedes mal 18 mal aufgebaut.
                                Um das zu verhindern wäre meine Idee nach dem Abspeichern ein JOIN zu machen und eine Sekunde zu warten. Dann geht es (hoffentlich) nur 1 mal weiter statt 18 mal.
                                Frage: fällt dir da eine elegantere Lösung ein?

                              Bei so viel Text sieht das wieder aus als hätte ich gern eine komplette Analyse - ist aber nicht die Intention, versprochen 😭

                              mickymM 1 Reply Last reply
                              0
                              • S Offline
                                S Offline
                                Schmetterfliege
                                wrote on last edited by
                                #245

                                Mal was ganz anderes:
                                Ich spiele grade mit den Link in/out/call Nodes rum.
                                Wofür ist denn die Link Call Node gut? Die hat leider keinerlei Eintrag im Handbuch

                                mickymM 1 Reply Last reply
                                0
                                • S Schmetterfliege

                                  @mickym

                                  Für mich war's aber Zeit 😁
                                  Mein Schlafrythmus ist seit 2 Jahren eher... "ungesund" und nicht grade optimal für mein Arbeitsleben - den muss ich langsam mal in die richtige Richtung drücken hehe.

                                  Ich stelle die Frage(n) nochmal und versuche keine komplette Flow-Analyse daraus zu machen 😀
                                  In meinem Flow wird alles möglich in die Kontextvariablen gepackt, zum Ende dann alle Variablen geladen und damit die Tabelle gebastelt. Soweit so gut.
                                  Um die Berechnung der Differenz zu machen muss ich ja auch den Kontext laden, die Berechnung machen und das dann wieder im Kontext speichern. Soweit auch so gut.

                                  Im Flow muss das ja passieren nachdem ich alle anderen Daten gesammelt habe und bevor ich die Tabelle erstelle.
                                  Deshalb mache ich die Berechnung direkt vor dem Erstellen der Tabelle.
                                  Meine Fragen:

                                  1. Um die Tabelle zu basteln muss ich vorher den Kontext in den Payload packen. Das alleine funktioniert aber nicht, sondern ich muss diesen Payload erst splitten und dann wieder joinen. -> Warum? Was für einen Unterschied macht es den Kontext zu übergeben vs. Kontext splitten dann wieder joinen und dann übergeben?
                                  2. Das Berechnen der Differenzen triggert ja jedes mal die nächste Node, was dann den Kontext lädt (splittet und joint) und dann die Tabelle erstellt. Ich berechne 18 Differenzen, d.h. long story short: die Tabelle wird jedes mal 18 mal aufgebaut.
                                    Um das zu verhindern wäre meine Idee nach dem Abspeichern ein JOIN zu machen und eine Sekunde zu warten. Dann geht es (hoffentlich) nur 1 mal weiter statt 18 mal.
                                    Frage: fällt dir da eine elegantere Lösung ein?

                                  Bei so viel Text sieht das wieder aus als hätte ich gern eine komplette Analyse - ist aber nicht die Intention, versprochen 😭

                                  mickymM Offline
                                  mickymM Offline
                                  mickym
                                  Most Active
                                  wrote on last edited by
                                  #246

                                  @schmetterfliege sagte in Verfügbarkeit von Sensoren über Node Red überwachen:

                                  Das alleine funktioniert aber nicht, sondern ich muss diesen Payload erst splitten und dann wieder joinen. -> Warum? Was für einen Unterschied macht es den Kontext zu übergeben vs. Kontext splitten dann wieder joinen und dann übergeben?

                                  Nun das ist einfach die Methode einzelne Objekte zu verändern - in der klassischen Programmierung würdest Du es über eine Schleife machen, die auch jedes einzelne Objekt anfasst. Du kannst auch function Nodes schreiben indem Du über Objekte oder Arrays iterierst. Das Ausplitten und joinen ist also dafür nötig, um letztlich ein Array von Objekten zu erzeugen, dass die table Node benötigt.

                                  Um das zu verhindern wäre meine Idee nach dem Abspeichern ein JOIN zu machen und eine Sekunde zu warten. Dann geht es (hoffentlich) nur 1 mal weiter statt 18 mal.

                                  Bei Arrays bleibt Dir sowieso nur die Zeit übrig - ich es ehrlich gesagt in Deinem Fall so machen würde, dass ich im Prinzip diese ganze Zeitstempel nach der letzten JOIN Node des ursprünglichen Flows einbauen würde. Da dann bereits die Anzahl der Elemente im Array unverändert bleibt, würde ich das Array aufsplitten und automatisch wieder zusammensetzen lassen. Dann würde ich nur für jede einzelne Nachricht die Zeitdifferenz berechnen lassen und in das Objekt mit aufzunehmen. Im Prinzip also von dem zentralen Flow Abschied nehmen. Über das initiale Einlesen hast Du ja alle Timestamps in Deiner Flow variable. Ich würde also einen anderen Ansatz nehmen.

                                  Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                                  S 1 Reply Last reply
                                  0
                                  • S Schmetterfliege

                                    Mal was ganz anderes:
                                    Ich spiele grade mit den Link in/out/call Nodes rum.
                                    Wofür ist denn die Link Call Node gut? Die hat leider keinerlei Eintrag im Handbuch

                                    mickymM Offline
                                    mickymM Offline
                                    mickym
                                    Most Active
                                    wrote on last edited by mickym
                                    #247

                                    @schmetterfliege sagte in Verfügbarkeit von Sensoren über Node Red überwachen:

                                    Mal was ganz anderes:
                                    Ich spiele grade mit den Link in/out/call Nodes rum.
                                    Wofür ist denn die Link Call Node gut? Die hat leider keinerlei Eintrag im Handbuch

                                    Ja die wäre für Dich geeignet. Ist - wie eine Art Unterprogramm aufzurufen. Wie gesagt fang mal an mit der ersten Initialisierung in Deinem Flow Kontext die Zeitstempel der Geräte mit den Topics als Objekteigenschaften zu sammeln . Die Zeitdifferenzen berechnest Du dann nach einem split hinter der letzten JOIN Node für jedes einzelne Objekt.

                                    Bei der CALL Node musst Du nur unbedingt darauf achten, dass die auf jeden Fall wieder zu aufrufenden Node zurück kehrt.

                                    Du machst also eine Call Node hinter die split Node und kannst dann über eine Link-In Node die Zeitdifferenzen berechnen .- die link-out Node musst dann so konfigurieren, dass diese wieder an die aufrufende Node zurückkehrt.

                                    Hier wieder das Video von meinem amerikansichen NodeRed Guru: https://www.youtube.com/watch?v=qryeuduhsoo

                                    Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                                    S 1 Reply Last reply
                                    0
                                    • mickymM mickym

                                      @schmetterfliege sagte in Verfügbarkeit von Sensoren über Node Red überwachen:

                                      Das alleine funktioniert aber nicht, sondern ich muss diesen Payload erst splitten und dann wieder joinen. -> Warum? Was für einen Unterschied macht es den Kontext zu übergeben vs. Kontext splitten dann wieder joinen und dann übergeben?

                                      Nun das ist einfach die Methode einzelne Objekte zu verändern - in der klassischen Programmierung würdest Du es über eine Schleife machen, die auch jedes einzelne Objekt anfasst. Du kannst auch function Nodes schreiben indem Du über Objekte oder Arrays iterierst. Das Ausplitten und joinen ist also dafür nötig, um letztlich ein Array von Objekten zu erzeugen, dass die table Node benötigt.

                                      Um das zu verhindern wäre meine Idee nach dem Abspeichern ein JOIN zu machen und eine Sekunde zu warten. Dann geht es (hoffentlich) nur 1 mal weiter statt 18 mal.

                                      Bei Arrays bleibt Dir sowieso nur die Zeit übrig - ich es ehrlich gesagt in Deinem Fall so machen würde, dass ich im Prinzip diese ganze Zeitstempel nach der letzten JOIN Node des ursprünglichen Flows einbauen würde. Da dann bereits die Anzahl der Elemente im Array unverändert bleibt, würde ich das Array aufsplitten und automatisch wieder zusammensetzen lassen. Dann würde ich nur für jede einzelne Nachricht die Zeitdifferenz berechnen lassen und in das Objekt mit aufzunehmen. Im Prinzip also von dem zentralen Flow Abschied nehmen. Über das initiale Einlesen hast Du ja alle Timestamps in Deiner Flow variable. Ich würde also einen anderen Ansatz nehmen.

                                      S Offline
                                      S Offline
                                      Schmetterfliege
                                      wrote on last edited by
                                      #248

                                      @mickym said in Verfügbarkeit von Sensoren über Node Red überwachen:

                                      @schmetterfliege sagte in Verfügbarkeit von Sensoren über Node Red überwachen:

                                      Das alleine funktioniert aber nicht, sondern ich muss diesen Payload erst splitten und dann wieder joinen. -> Warum? Was für einen Unterschied macht es den Kontext zu übergeben vs. Kontext splitten dann wieder joinen und dann übergeben?

                                      Nun das ist einfach die Methode einzelne Objekte zu verändern - in der klassischen Programmierung würdest Du es über eine Schleife machen, die auch jedes einzelne Objekt anfasst. Du kannst auch function Nodes schreiben indem Du über Objekte oder Arrays iterierst. Das Ausplitten und joinen ist also dafür nötig, um letztlich ein Array von Objekten zu erzeugen, dass die table Node benötigt.

                                      Wow, ich schäme mich gerade echt überhaupt die Frage gestellt zu haben.
                                      In der Node ist doch klar ersichtlich dass er ein Array erstellt und nicht wieder einen einzigen Payload... I'm sorry :(
                                      Die Function Node baut die Tabelle dann für jeden Eintrag im Array, also jede Zeile.
                                      Ganz ehrlich, dass mir jetzt erst klar wird bzw ich realisiere wie das was ich da mache funktioniert (oder wieder?) bringt mich grade echt so ein bisschen an den Rand der Verzweiflung...
                                      Wirklich, ganz herzlichen Dank dass du dich trotzdem mit mir außeinandersetzt!

                                      Um das zu verhindern wäre meine Idee nach dem Abspeichern ein JOIN zu machen und eine Sekunde zu warten. Dann geht es (hoffentlich) nur 1 mal weiter statt 18 mal.

                                      Bei Arrays bleibt Dir sowieso nur die Zeit übrig - ich es ehrlich gesagt in Deinem Fall so machen würde, dass ich im Prinzip diese ganze Zeitstempel nach der letzten JOIN Node des ursprünglichen Flows einbauen würde. Da dann bereits die Anzahl der Elemente im Array unverändert bleibt, würde ich das Array aufsplitten und automatisch wieder zusammensetzen lassen. Dann würde ich nur für jede einzelne Nachricht die Zeitdifferenz berechnen lassen und in das Objekt mit aufzunehmen. Im Prinzip also von dem zentralen Flow Abschied nehmen. Über das initiale Einlesen hast Du ja alle Timestamps in Deiner Flow variable. Ich würde also einen anderen Ansatz nehmen.

                                      Guter Ansatz, ich werde das versuchen so umzusetzen wenn ich das mit den Link Nodes verstanden und umgesetzt habe um aufzuräumen :)

                                      mickymM 1 Reply Last reply
                                      0
                                      • mickymM mickym

                                        @schmetterfliege sagte in Verfügbarkeit von Sensoren über Node Red überwachen:

                                        Mal was ganz anderes:
                                        Ich spiele grade mit den Link in/out/call Nodes rum.
                                        Wofür ist denn die Link Call Node gut? Die hat leider keinerlei Eintrag im Handbuch

                                        Ja die wäre für Dich geeignet. Ist - wie eine Art Unterprogramm aufzurufen. Wie gesagt fang mal an mit der ersten Initialisierung in Deinem Flow Kontext die Zeitstempel der Geräte mit den Topics als Objekteigenschaften zu sammeln . Die Zeitdifferenzen berechnest Du dann nach einem split hinter der letzten JOIN Node für jedes einzelne Objekt.

                                        Bei der CALL Node musst Du nur unbedingt darauf achten, dass die auf jeden Fall wieder zu aufrufenden Node zurück kehrt.

                                        Du machst also eine Call Node hinter die split Node und kannst dann über eine Link-In Node die Zeitdifferenzen berechnen .- die link-out Node musst dann so konfigurieren, dass diese wieder an die aufrufende Node zurückkehrt.

                                        Hier wieder das Video von meinem amerikansichen NodeRed Guru: https://www.youtube.com/watch?v=qryeuduhsoo

                                        S Offline
                                        S Offline
                                        Schmetterfliege
                                        wrote on last edited by
                                        #249

                                        @mickym said in Verfügbarkeit von Sensoren über Node Red überwachen:

                                        @schmetterfliege sagte in Verfügbarkeit von Sensoren über Node Red überwachen:

                                        Mal was ganz anderes:
                                        Ich spiele grade mit den Link in/out/call Nodes rum.
                                        Wofür ist denn die Link Call Node gut? Die hat leider keinerlei Eintrag im Handbuch

                                        Ja die wäre für Dich geeignet. Ist - wie eine Art Unterprogramm aufzurufen. Wie gesagt fang mal an mit der ersten Initialisierung in Deinem Flow Kontext die Zeitstempel der Geräte mit den Topics als Objekteigenschaften zu sammeln . Die Zeitdifferenzen berechnest Du dann nach einem split hinter der letzten JOIN Node für jedes einzelne Objekt.

                                        Bei der CALL Node musst Du nur unbedingt darauf achten, dass die auf jeden Fall wieder zu aufrufenden Node zurück kehrt.

                                        Du machst also eine Call Node hinter die split Node und kannst dann über eine Link-In Node die Zeitdifferenzen berechnen .- die link-out Node musst dann so konfigurieren, dass diese wieder an die aufrufende Node zurückkehrt.

                                        Hier wieder das Video von meinem amerikansichen NodeRed Guru: https://www.youtube.com/watch?v=qryeuduhsoo

                                        Danke dir für den Link und den Input!
                                        Die Funktion der Nodes ist absolut selbsterklärend, keine Ahnung warum ich mit "return to calling node" nicht gecheckt habe dass damit literally die "Link Call" Node gemeint ist.
                                        Entweder ich bin wirklich so stupide, oder ich sollte aufhören mich erst nach Mitternacht mit NR zu beschäftigen..ich geh mich gleich vergraben^^

                                        mickymM 1 Reply Last reply
                                        0
                                        • S Schmetterfliege

                                          @mickym said in Verfügbarkeit von Sensoren über Node Red überwachen:

                                          @schmetterfliege sagte in Verfügbarkeit von Sensoren über Node Red überwachen:

                                          Das alleine funktioniert aber nicht, sondern ich muss diesen Payload erst splitten und dann wieder joinen. -> Warum? Was für einen Unterschied macht es den Kontext zu übergeben vs. Kontext splitten dann wieder joinen und dann übergeben?

                                          Nun das ist einfach die Methode einzelne Objekte zu verändern - in der klassischen Programmierung würdest Du es über eine Schleife machen, die auch jedes einzelne Objekt anfasst. Du kannst auch function Nodes schreiben indem Du über Objekte oder Arrays iterierst. Das Ausplitten und joinen ist also dafür nötig, um letztlich ein Array von Objekten zu erzeugen, dass die table Node benötigt.

                                          Wow, ich schäme mich gerade echt überhaupt die Frage gestellt zu haben.
                                          In der Node ist doch klar ersichtlich dass er ein Array erstellt und nicht wieder einen einzigen Payload... I'm sorry :(
                                          Die Function Node baut die Tabelle dann für jeden Eintrag im Array, also jede Zeile.
                                          Ganz ehrlich, dass mir jetzt erst klar wird bzw ich realisiere wie das was ich da mache funktioniert (oder wieder?) bringt mich grade echt so ein bisschen an den Rand der Verzweiflung...
                                          Wirklich, ganz herzlichen Dank dass du dich trotzdem mit mir außeinandersetzt!

                                          Um das zu verhindern wäre meine Idee nach dem Abspeichern ein JOIN zu machen und eine Sekunde zu warten. Dann geht es (hoffentlich) nur 1 mal weiter statt 18 mal.

                                          Bei Arrays bleibt Dir sowieso nur die Zeit übrig - ich es ehrlich gesagt in Deinem Fall so machen würde, dass ich im Prinzip diese ganze Zeitstempel nach der letzten JOIN Node des ursprünglichen Flows einbauen würde. Da dann bereits die Anzahl der Elemente im Array unverändert bleibt, würde ich das Array aufsplitten und automatisch wieder zusammensetzen lassen. Dann würde ich nur für jede einzelne Nachricht die Zeitdifferenz berechnen lassen und in das Objekt mit aufzunehmen. Im Prinzip also von dem zentralen Flow Abschied nehmen. Über das initiale Einlesen hast Du ja alle Timestamps in Deiner Flow variable. Ich würde also einen anderen Ansatz nehmen.

                                          Guter Ansatz, ich werde das versuchen so umzusetzen wenn ich das mit den Link Nodes verstanden und umgesetzt habe um aufzuräumen :)

                                          mickymM Offline
                                          mickymM Offline
                                          mickym
                                          Most Active
                                          wrote on last edited by
                                          #250

                                          @schmetterfliege

                                          Ich habe noch rundimentäre Teile unserer Nodes gefunden - aber ich werde Deinen Flow nicht mehr importieren - da ich auch den Zigbee Adapter nicht mehr verwende.

                                          Also wie gesagt, wenn Du bei der Initialisierung die Timestamps in einem Flow Objekt gespeichert hast, dann kannst Du eine link call Node verwenden, aber eigentlich rentiert es sich nicht weil wahrscheinlich eine einfache Change Node ausreichnen würde:

                                          Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                                          1 Reply Last reply
                                          0

                                          Hello! It looks like you're interested in this conversation, but you don't have an account yet.

                                          Getting fed up of having to scroll through the same posts each visit? When you register for an account, you'll always come back to exactly where you were before, and choose to be notified of new replies (either via email, or push notification). You'll also be able to save bookmarks and upvote posts to show your appreciation to other community members.

                                          With your input, this post could be even better 💗

                                          Register Login
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate
                                          FAQ Cloud / IOT
                                          HowTo: Node.js-Update
                                          HowTo: Backup/Restore
                                          Downloads
                                          BLOG

                                          281

                                          Online

                                          32.7k

                                          Users

                                          82.6k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe