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
    16
    1
    364

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

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

Abfrage der Erreichbarkeit der Sensoren

Scheduled Pinned Locked Moved Skripten / Logik
blockly
25 Posts 5 Posters 2.9k 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.
  • 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
            Reply
            • Reply as topic
            Log in to reply
            • Oldest to Newest
            • Newest to Oldest
            • Most Votes


            Support us

            ioBroker
            Community Adapters
            Donate

            692

            Online

            32.7k

            Users

            82.5k

            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