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. Skripten / Logik
  4. Abfrage der Erreichbarkeit der Sensoren

NEWS

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

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

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

Abfrage der Erreichbarkeit der Sensoren

Scheduled Pinned Locked Moved Skripten / Logik
blockly
25 Posts 5 Posters 3.0k Views 3 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.
  • paul53P paul53

    @dgr sagte: Nachteil ist, dass ich dann auch in ioBroker-vis wieder an einigen Stellen Änderungen vornehmen muss und leider dann auch im o.g. Blockly.

    Um diesen Nachteil zu vermeiden, gibt es Alias. Dann muss nur noch an einer Stelle angepasst werden.

    D Offline
    D Offline
    DGR
    wrote on last edited by
    #11

    @paul53 Danke. Das kannte ich nicht. Bei mir gibt es im Objektbaum alias, darunter 0 aber sonst nichts. Da muss ich mich erstmal mit befassen, aber gut, dass es eine solche Möglichkeit gibt.

    1 Reply Last reply
    0
    • ? A Former User

      @dgr
      Im Spoiler ist mein Blockly drin.
      Wenn das lastupdated = dem "Zuletzt geändert" steht dann kannst du daran die Verbindung nicht testen. Der Zeitstempel ändert sich bei mir nicht mehr wenn die Verbindung verloren geht. Somit bleibt nach der eingestellten Abfragezeit die Zeit gleich und es kommt eine Meldung.

      D Offline
      D Offline
      DGR
      wrote on last edited by DGR
      #12

      @brainbug
      heute: 27.05.2022
      Ich habe einen Fenster-/Türsensor mit:
      Zeitstempel.JPG
      Wert von "lastupdated" = 2022-05-22T13.57 ....
      Zeitstempel = 2022-05-26 04:38....
      Zuletzt geändert = 2022-05-22T13:57 ....

      Der Sensor arbeitet mindestens seit 4 Tagen nicht mehr, also Annahme seit 22.05.22 (lastupdated/Zuletzt geändert).
      Es ist eigentlich egal, seit wann er nicht mehr arbeitet. Wichtig ist nur, dass erkannt wird, dass er nicht mehr arbeitet und das läuft ja.
      Trotzdem bleibt die Frage für mich, was bedeutet der Wert von "lastupdated" (bzw. "zuletzt aktualisiert") ?
      Der Zeitstempel hat sich gestern zuletzt geändert. Wodurch aber ?

      1 Reply Last reply
      0
      • ? Offline
        ? Offline
        A Former User
        wrote on last edited by A Former User
        #13

        @DGR Ah, jetzt sehe ich das auch das beim deconz den Wert lastupdated gibt. Kannst du mal bei battery schauen welcher Zeitstempel dort angezeigt wird?

        D 1 Reply Last reply
        0
        • ? A Former User

          @DGR Ah, jetzt sehe ich das auch das beim deconz den Wert lastupdated gibt. Kannst du mal bei battery schauen welcher Zeitstempel dort angezeigt wird?

          D Offline
          D Offline
          DGR
          wrote on last edited by
          #14

          @brainbug
          auch 26.05.22
          Zeitstempel.JPG

          seltsam: "Zuletzt geändert: 2022-03-23 ...."

          andere Zeitstempel:
          Zeitstempel3.JPG Zeitstempel2.JPG

          paul53P 1 Reply Last reply
          0
          • paul53P paul53

            @dgr sagte: Nachteil ist, dass ich dann auch in ioBroker-vis wieder an einigen Stellen Änderungen vornehmen muss und leider dann auch im o.g. Blockly.

            Um diesen Nachteil zu vermeiden, gibt es Alias. Dann muss nur noch an einer Stelle angepasst werden.

            D Offline
            D Offline
            DGR
            wrote on last edited by
            #15

            @paul53 Ich habe festgestellt, dass mit Alias nicht alles so läuft wie direkt vom Objekt:
            Alias02.JPG Alias01.JPG

            paul53P 1 Reply Last reply
            0
            • D DGR

              @paul53 Ich habe festgestellt, dass mit Alias nicht alles so läuft wie direkt vom Objekt:
              Alias02.JPG Alias01.JPG

              paul53P Offline
              paul53P Offline
              paul53
              wrote on last edited by paul53
              #16

              @dgr sagte: festgestellt, dass mit Alias nicht alles so läuft wie direkt vom Objekt:

              Das kann ich bei mir nicht nachvollziehen. Aktualisiere mal den Original-Datenpunkt ohne den Wert zu ändern mit "Bestätigt".

              Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
              Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

              D 1 Reply Last reply
              0
              • D DGR

                @brainbug
                auch 26.05.22
                Zeitstempel.JPG

                seltsam: "Zuletzt geändert: 2022-03-23 ...."

                andere Zeitstempel:
                Zeitstempel3.JPG Zeitstempel2.JPG

                paul53P Offline
                paul53P Offline
                paul53
                wrote on last edited by paul53
                #17

                @dgr sagte: seltsam: "Zuletzt geändert: 2022-03-23

                Was ist daran seltsam? Immer noch 100 % (keine Wertänderung).

                "indicator.reachable" wurde durch ein Skript aktualisiert!

                Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                D 1 Reply Last reply
                0
                • paul53P paul53

                  @dgr sagte: festgestellt, dass mit Alias nicht alles so läuft wie direkt vom Objekt:

                  Das kann ich bei mir nicht nachvollziehen. Aktualisiere mal den Original-Datenpunkt ohne den Wert zu ändern mit "Bestätigt".

                  D Offline
                  D Offline
                  DGR
                  wrote on last edited by
                  #18

                  @paul53
                  Wie meinst du das mit Aktualisieren des Datenpunktes ? Das ist ein Sensor, der aktuell nicht erreichbar ist.
                  Bestätigt ist "true".

                  paul53P 1 Reply Last reply
                  0
                  • D DGR

                    @paul53
                    Wie meinst du das mit Aktualisieren des Datenpunktes ? Das ist ein Sensor, der aktuell nicht erreichbar ist.
                    Bestätigt ist "true".

                    paul53P Offline
                    paul53P Offline
                    paul53
                    wrote on last edited by
                    #19

                    @dgr sagte: Wie meinst du das mit Aktualisieren des Datenpunktes ?

                    Im Tab "Objekte" den existierenden Wert mit Bestätigt "true" noch mal absenden, damit getriggert wird (für den Alias).

                    Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                    Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                    1 Reply Last reply
                    0
                    • paul53P paul53

                      @dgr sagte: seltsam: "Zuletzt geändert: 2022-03-23

                      Was ist daran seltsam? Immer noch 100 % (keine Wertänderung).

                      "indicator.reachable" wurde durch ein Skript aktualisiert!

                      D Offline
                      D Offline
                      DGR
                      wrote on last edited by
                      #20

                      @paul53
                      ein Datenpunkt eines Sensors, der aktuell nicht erreichbar ist. Es wurde "reachable" für die Darstellung in vis auf "falsch" gesetzt, weil nicht erreichbar.

                      paul53P 1 Reply Last reply
                      0
                      • D DGR

                        @paul53
                        ein Datenpunkt eines Sensors, der aktuell nicht erreichbar ist. Es wurde "reachable" für die Darstellung in vis auf "falsch" gesetzt, weil nicht erreichbar.

                        paul53P Offline
                        paul53P Offline
                        paul53
                        wrote on last edited by paul53
                        #21

                        @dgr sagte: Es wurde "reachable" für die Darstellung in vis auf "falsch" gesetzt, weil nicht erreichbar.

                        Ja, mittels Skript. Ist "reachable" nicht "read only" (indicator)?

                        Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                        Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                        D 1 Reply Last reply
                        0
                        • paul53P paul53

                          @dgr sagte: Es wurde "reachable" für die Darstellung in vis auf "falsch" gesetzt, weil nicht erreichbar.

                          Ja, mittels Skript. Ist "reachable" nicht "read only" (indicator)?

                          D Offline
                          D Offline
                          DGR
                          wrote on last edited by DGR
                          #22

                          @paul53
                          funktioniert ! Anderer Sensor (ist erreichbar):
                          reachable_steuern.JPG

                          paul53P 1 Reply Last reply
                          0
                          • D DGR

                            @paul53
                            funktioniert ! Anderer Sensor (ist erreichbar):
                            reachable_steuern.JPG

                            paul53P Offline
                            paul53P Offline
                            paul53
                            wrote on last edited by paul53
                            #23

                            @dgr sagte: Anderer Sensor (ist erreichbar):

                            Man sollte einen "read only" Datenpunkt eines Adapters nicht per Skript schreiben. Die gehören dem Adapter!

                            Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                            Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                            D 1 Reply Last reply
                            0
                            • paul53P paul53

                              @dgr sagte: Anderer Sensor (ist erreichbar):

                              Man sollte einen "read only" Datenpunkt eines Adapters nicht per Skript schreiben. Die gehören dem Adapter!

                              D Offline
                              D Offline
                              DGR
                              wrote on last edited by
                              #24

                              @paul53
                              dann werde ich mir wohl für die Erreichbarkeit der Adapter eigene Datenpunkte anlegen müssen.
                              War das nun die Ursache für die Unterschiede Objekt-Alias ?
                              Ich teste das mal und melde mich mit den Ergebnissen (kann aber dauern).

                              1 Reply Last reply
                              0
                              • htreckslerH htrecksler

                                @brainbug muss es unbedingt Blockly sein?
                                Bei mir läuft ein javascript welches einen Bodenfeuchtesensor überwacht.
                                Hab ich irgendwann mal hier im Forum gefunden und es läuft recht zuverlässig, ist jedoch kein Blockly.

                                //Das Script überprüft regelmässig die Datenpunkte auf Aktualisierung
                                 
                                //Angabe des Datenpunkts= Datenpunkt der Überwacht werden soll
                                //StateBezeichnung= Unter pfad_javascript.StateBezeichung wird ein State angelegt; True = Daten sind aktuell / False = Daten veraltet
                                //Zeit in Sekunden = Zeit die vergangen sein darf seit der letzen Aktualisierung des Datenpunkts  (0 = default Zeit wird genommen).
                                 
                                schedule("*/3 * * * *" , function () {                                  
                                 
                                    // Angabe des Datenpunkts;StateBezeichnung;Zeit in Sekunden
                                    var ueberwachung = ['mqtt.0.Sensoren.Sensor03.Feuchtigkeit;Bodenfeuchte_Hinten;660', 
                                                        'mqtt.0.Sensoren.Sensor02.Feuchtigkeit;Bodenfeuchte_Vorne;660'];
                                
                                 
                                    var default_zeit = 400;
                                    var pfad_userdata ='0_userdata.0.watchdog.';   // !Punkt nicht vergessen am Ende!
                                 
                                 
                                    //------------------------------------------------------------------
                                    //Ab hier nichts mehr Ändern
                                    //------------------------------------------------------------------
                                    var zeit= Math.floor(Date.now() / 1000);
                                    var differenz, lchange;
                                    var daten, tchange;
                                 
                                    ueberwachung.forEach(function(item, index, array) 
                                    {
                                        // Array Splitten
                                           daten = item.split(";");
                                 
                                        //Datenpunkt erstellen wenn nicht vorhanden
                                            createState(pfad_userdata + daten[1], { read: true, write: false, name: "Watchdog " + daten[1], type: "boolean", role: " ", def: "false"});
                                 
                                        //Differenz Zeit default oder manuell?
                                            differenz = parseInt(daten[2]);
                                            if (differenz == 0) differenz=default_zeit;
                                 
                                        //Zeitstempel abfragen in Sekunden
                                            tchange=parseInt(getState(daten[0]).ts / 1000);
                                            
                                        //Vergleichen der Zeitstempel
                                                if ((zeit-tchange)>differenz)
                                                {
                                                    setState(pfad_userdata + daten[1], false);
                                                    //setState("telegram.0.communicate.response", daten[1] + ' - ' + "Info: Sensor nicht erreichbar");
                                                    //console.log(daten[1] + "  ist älter als " + differenz + " Sekunden", 'warn');
                                                }
                                                else
                                                {
                                                    setState(pfad_userdata + daten[1], true);
                                                    //console.log(daten[1] + "  ist jünger als " + differenz + " Sekunden");
                                                } 
                                 
                                    });  
                                });
                                 
                                
                                
                                H Offline
                                H Offline
                                hmarius1
                                wrote on last edited by
                                #25

                                @htrecksler ich habe das mal ein bisschen überarbeitet. Der createState war nicht korrekte und das Log hat Fehler geworfen. Das Objekt was angelegt wurde war nur Read Only.

                                Hier die angepasste Version:

                                //Das Script überprüft regelmässig die Datenpunkte auf Aktualisierung
                                
                                 
                                
                                //Angabe des Datenpunkts= Datenpunkt der Überwacht werden soll
                                
                                //StateBezeichnung= Unter pfad_javascript.StateBezeichung wird ein State angelegt; True = Daten sind aktuell / False = Daten veraltet
                                
                                //Zeit in Sekunden = Zeit die vergangen sein darf seit der letzen Aktualisierung des Datenpunkts  (0 = default Zeit wird genommen).
                                
                                 
                                
                                schedule("*/3 * * * *" , function () {                                  
                                
                                 
                                
                                    // Angabe des Datenpunkts;StateBezeichnung;Zeit in Sekunden
                                
                                    var ueberwachung = ['mqtt.0.Wetterstation.Batterie;Wetterstation;440'];
                                
                                 
                                
                                 
                                
                                    var default_zeit = 400;
                                
                                    var pfad_userdata ='0_userdata.0.watchdog.';   // !Punkt nicht vergessen am Ende!
                                
                                 
                                
                                 
                                
                                    //------------------------------------------------------------------
                                
                                    //Ab hier nichts mehr Ändern
                                
                                    //------------------------------------------------------------------
                                
                                    var zeit= Math.floor(Date.now() / 1000);
                                
                                    var differenz, lchange;
                                
                                    var daten, tchange;
                                
                                 
                                
                                    ueberwachung.forEach(function(item, index, array) 
                                
                                    {
                                
                                        // Array Splitten
                                
                                           daten = item.split(";");
                                
                                 
                                
                                        //Datenpunkt erstellen wenn nicht vorhanden
                                
                                            createState(pfad_userdata + daten[1], {
                                                read: true,
                                                write: true,
                                                name: "Watchdog " + daten[1],
                                                type: "boolean",
                                                def: false
                                            } )
                                
                                 
                                
                                        //Differenz Zeit default oder manuell?
                                
                                            differenz = parseInt(daten[2]);
                                
                                            if (differenz == 0) differenz=default_zeit;
                                
                                 
                                
                                        //Zeitstempel abfragen in Sekunden
                                
                                            tchange=parseInt(getState(daten[0]).ts / 1000);
                                
                                            
                                
                                        //Vergleichen der Zeitstempel
                                
                                                if ((zeit-tchange)>differenz)
                                
                                                {
                                
                                                    setState(pfad_userdata + daten[1], false);
                                
                                                    //setState("telegram.0.communicate.response", daten[1] + ' - ' + "Info: Sensor nicht erreichbar");
                                
                                                    //console.log(daten[1] + "  ist älter als " + differenz + " Sekunden", 'warn');
                                
                                                }
                                
                                                else
                                
                                                {
                                
                                                    setState(pfad_userdata + daten[1], true);
                                
                                                    //console.log(daten[1] + "  ist jünger als " + differenz + " Sekunden");
                                
                                                } 
                                
                                 
                                
                                    });  
                                
                                });
                                
                                1 Reply Last reply
                                1

                                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

                                433

                                Online

                                32.8k

                                Users

                                82.7k

                                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