Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • 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

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Abfrage der Erreichbarkeit der Sensoren

NEWS

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    11
    1
    357

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    24
    1
    1.6k

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    9.5k

Abfrage der Erreichbarkeit der Sensoren

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
blockly
25 Beiträge 5 Kommentatoren 2.8k Aufrufe 3 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • 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
    schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
    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
      schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
      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
        schrieb am zuletzt editiert von
        #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 Antwort Letzte Antwort
        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
          schrieb am zuletzt editiert von
          #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 Antwort Letzte Antwort
          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
            schrieb am zuletzt editiert von
            #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 Antwort Letzte Antwort
            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
              schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
              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
                schrieb am zuletzt editiert von DGR
                #22

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

                paul53P 1 Antwort Letzte Antwort
                0
                • D DGR

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

                  paul53P Offline
                  paul53P Offline
                  paul53
                  schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                  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
                    schrieb am zuletzt editiert von
                    #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 Antwort Letzte Antwort
                    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
                      schrieb am zuletzt editiert von
                      #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 Antwort Letzte Antwort
                      1
                      Antworten
                      • In einem neuen Thema antworten
                      Anmelden zum Antworten
                      • Älteste zuerst
                      • Neuste zuerst
                      • Meiste Stimmen


                      Support us

                      ioBroker
                      Community Adapters
                      Donate

                      516

                      Online

                      32.5k

                      Benutzer

                      81.8k

                      Themen

                      1.3m

                      Beiträge
                      Community
                      Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                      ioBroker Community 2014-2025
                      logo
                      • Anmelden

                      • Du hast noch kein Konto? Registrieren

                      • Anmelden oder registrieren, um zu suchen
                      • Erster Beitrag
                        Letzter Beitrag
                      0
                      • Home
                      • Aktuell
                      • Tags
                      • Ungelesen 0
                      • Kategorien
                      • Unreplied
                      • Beliebt
                      • GitHub
                      • Docu
                      • Hilfe