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. JavaScript
  5. Skript PING

NEWS

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    24
    1
    1.7k

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

Skript PING

Geplant Angeheftet Gesperrt Verschoben JavaScript
15 Beiträge 6 Kommentatoren 1.5k Aufrufe 8 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.
  • MyzerATM MyzerAT

    @ro75

    hab ich gemacht, wenn ich enter drücke tut sich nichts

    Screenshot_20241020_131040_Samsung Internet.jpg

    Thomas BraunT Online
    Thomas BraunT Online
    Thomas Braun
    Most Active
    schrieb am zuletzt editiert von
    #5

    @myzerat

    Kleinbuchstaben...
    ping also

    Linux-Werkzeugkasten:
    https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
    NodeJS Fixer Skript:
    https://forum.iobroker.net/topic/68035/iob-node-fix-skript
    iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

    MyzerATM 1 Antwort Letzte Antwort
    1
    • Thomas BraunT Thomas Braun

      @myzerat

      Kleinbuchstaben...
      ping also

      MyzerATM Offline
      MyzerATM Offline
      MyzerAT
      schrieb am zuletzt editiert von
      #6

      @thomas-braun

      ja hab ich auch probiert

      lg Rudi

      Master Debian 12 (Wien)
      Intel NUC6CAYH 16GB RAM, 500 GB SSD & auf Proxmox 8. 7. als VM

      Slave Debian 12. (TULLN) --> OpenVPN to Vienna
      Intel NUC6CAYH 16GB RAM, 500 GB SSD & auf Proxmox 8.7. als VM

      Node 20.19.0
      Nodejs 20.19.0
      npm 10.8.2
      js-controller 7.0.6

      Thomas BraunT 1 Antwort Letzte Antwort
      0
      • MyzerATM MyzerAT

        @thomas-braun

        ja hab ich auch probiert

        Thomas BraunT Online
        Thomas BraunT Online
        Thomas Braun
        Most Active
        schrieb am zuletzt editiert von
        #7

        @myzerat

        Keine Ahnung was du da machst. Geht hier sofort:

        300d275c-9d69-40a9-8882-7d5a21fb263d-grafik.png

        Linux-Werkzeugkasten:
        https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
        NodeJS Fixer Skript:
        https://forum.iobroker.net/topic/68035/iob-node-fix-skript
        iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

        MyzerATM 1 Antwort Letzte Antwort
        0
        • Thomas BraunT Thomas Braun

          @myzerat

          Keine Ahnung was du da machst. Geht hier sofort:

          300d275c-9d69-40a9-8882-7d5a21fb263d-grafik.png

          MyzerATM Offline
          MyzerATM Offline
          MyzerAT
          schrieb am zuletzt editiert von MyzerAT
          #8

          @thomas-braun

          ich bin auf eine samsung tablett s9 ultra mit dem samsung browser am probieren gewesen, mit dem firefox browser hat es sofort geklappt, komisch

          Screenshot_20241020_132134_Samsung Internet.jpg

          lg Rudi

          Master Debian 12 (Wien)
          Intel NUC6CAYH 16GB RAM, 500 GB SSD & auf Proxmox 8. 7. als VM

          Slave Debian 12. (TULLN) --> OpenVPN to Vienna
          Intel NUC6CAYH 16GB RAM, 500 GB SSD & auf Proxmox 8.7. als VM

          Node 20.19.0
          Nodejs 20.19.0
          npm 10.8.2
          js-controller 7.0.6

          1 Antwort Letzte Antwort
          0
          • B Online
            B Online
            BigMike71
            schrieb am zuletzt editiert von
            #9

            vielen dank für dein Script!
            Funktioniert mit meinem Qnap NAS super :)
            Schalte damit über ein Blockly zusätzlich ein Festplatten Array was über USB3 damit verbunden ist ein und aus

            1 Antwort Letzte Antwort
            0
            • Ro75R Ro75

              Hallo. Heute stelle ich euch einmal mein Skript "PING" vor. Wie der Name schon vermuten lässt, werden Daten zur Erreichbarkeit von (W)LAN-Geräten abgefragt und in atenpunkten gespeichert.

              Ach ja. Da gibt es einen Adapter. Im Grunde genommen, liefert das Skript fast die selben Daten.

              Warum nun aber das Skript? Der Hauptvorteil für mich ist, ich muss nicht einen weiteren Adapter pflegen (Updates). Und von den Ressourcen kann ich mir auch ein paar sparen, da der JS-Adapter sowieso läuft.

              VORAUSSETZUNGEN:

              Im JS-Adapter muss "ping" als zusätzliches NPM-Modul eingetragen sein

              d2cf192f-3d6e-4684-a9d0-347b8b42be98-image.png

              //Version 1.0.0 - 04.10.2024
              //Ersteller Ro75.
              
              //Voraussetzungen (Version 1.0.0 getestet mit)
              //NodeJS: 20.x
              //Javascript-Adapter: 8.7.6
              //Admin-Adapter: 7.0.23
              //JS-Controller: 6.0.11
              
              //"normale" Geräte ("Computer, Router, Switch, HUB, NAS, WLAN-Steckdosen, Android-Smartphone, Android-Tablet, etc.")
              //Amazon Echos, SKY-Geräte und diverse Konsolen (einfach probieren) funktionieren nicht.
              
              const ping          = require('ping');          //Im Javascript-Adapter einzutragen (Zusätzliche NPM-Module)
              const sMainPath     = '0_userdata.0.Ping.';     //zentraler Datenpunkt
              
              //Konfiguration der abzufragenden Geräte. Geräte werden duch "Doppelpunkt" (:) getrennt.
              //Jedes Geräte besteht aus zwei Werten. Die Werte werden durch Komma (,) getrennt.
              //Linksvom Kommadie Bezeichnung und rechts vom Komma die IP-Adresse
              const cDevicePing   = 'Device-1,192.168.XXX.XXX:Device-2,192.168.XXX.XXX:Device-3,192.168.XXX.XXX'; //bitte anpassen
              
              //Datenpunkte anlegen
              function PingInitalisierung(){
                  let sDevice = cDevicePing.split(':');
                  for (let i = 0; i <= sDevice.length-1; i++) {
                      let device_data = sDevice[i].split(',');
                      createState(sMainPath+device_data[0], '', {name: device_data[1],read: true, write: true});
                      createState(sMainPath+device_data[0]+'.Ping.alive', false, {name: 'Pingstatus' ,type: 'boolean', read: true, write: true});
                      createState(sMainPath+device_data[0]+'.Ping.time', 0, {name: 'Zeit' ,type: 'number', read: true, write: true, unit: 'ms'});
                      createState(sMainPath+device_data[0]+'.Ping.status', '', {name: 'Status' ,type: 'string', read: true, write: true});
                  }
              }
              //START
              PingInitalisierung();
              
              async function pingHost(host,sDesc) {
                  try {
                      const res = await ping.promise.probe(host, {timeout: 2, deadline: 2, packetSize: 16});
                      setState(sMainPath+sDesc+'.Ping.alive', JSON.parse(JSON.stringify(res)).alive, true);
                      setState(sMainPath+sDesc+'.Ping.time', parseFloat(JSON.parse(JSON.stringify(res)).time), true);
                      setState(sMainPath+sDesc+'.Ping.status', 'OK', true);
                  } catch (error) {
                      setState(sMainPath+sDesc+'.Ping.status', 'ERROR', true);
                  }
              }
              
              //Ping aller 10 Sekunden - kann angepasst werden - kleinerer Wert nicht empfohlen
              //damit das Intervall (wenn zu niedrig) nicht "gesprengt" wird: Schleife sperren und am Ende wieder freigeben
              let bPingSperre = false;
              schedule('*/10 * * * * *', async function StartPing() {
                  if (bPingSperre == false) {
                      bPingSperre = true;
                      let sDevice = cDevicePing.split(':');
                      for (let i = 0; i <= sDevice.length-1; i++) {
                          await pingHost(sDevice[i].split(',')[1],sDevice[i].split(',')[0]);
                      }
                      bPingSperre = false;
                  }
              });
              

              Wünsche Euch viel Erfolg bei der Umsetzung.

              Ro75.

              E Offline
              E Offline
              emil70
              schrieb am zuletzt editiert von emil70
              #10

              @ro75

              super script von dir

              Kann du sagen, warum Amazon Echos nicht gehen?

              Mein Alexa-Echo-Show2 und FireTVStick wird als "true" angezeigt. Die Dot leider nicht

              Edit: Was sagt den der Status "OK" aus bei jedem Netzwerkgerät

              gruss emil70

              iobroker(V9) und Pi-hole läuft über docker (js-controller 6.0.11 und admin v7.1.15) auf einem synology DS918+ mit DSM 7.1.1-42962 Update 6

              AsgothianA 1 Antwort Letzte Antwort
              0
              • E emil70

                @ro75

                super script von dir

                Kann du sagen, warum Amazon Echos nicht gehen?

                Mein Alexa-Echo-Show2 und FireTVStick wird als "true" angezeigt. Die Dot leider nicht

                Edit: Was sagt den der Status "OK" aus bei jedem Netzwerkgerät

                AsgothianA Offline
                AsgothianA Offline
                Asgothian
                Developer
                schrieb am zuletzt editiert von Asgothian
                #11

                @emil70 sagte in Skript PING:

                @ro75

                super script von dir

                Kann du sagen, warum Amazon Echos nicht gehen?

                Mein Alexa-Echo-Show2 und FireTVStick wird als "true" angezeigt. Die Dot leider nicht

                Edit: Was sagt den der Status "OK" aus bei jedem Netzwerkgerät

                Das kannst du selber ausprobieren:
                per konsole schickst du mal ein 'ping <IP.DES.ECHO.DOT> ab und schaust dir die Antwort an.

                Es ist denkbar das die Firmware des EchoDot die Antworten auf ICMP Requests blockiert. Das würdest Du da dann sehen (oder auch andere Fehlermeldungen warum das nicht geht)

                Das OK sagt aus das der Befehl sauber abgearbeitet wurde. Im Falle eines 'ERROR' ist auf deinem System etwas faul was dazu führt das die Pings nicht ausgeführt werden können.

                A.

                ioBroker auf RPi4 - Hardware soweit wie möglich via Zigbee.
                "Shit don't work" ist keine Fehlermeldung, sondern ein Fluch.

                E 1 Antwort Letzte Antwort
                1
                • AsgothianA Asgothian

                  @emil70 sagte in Skript PING:

                  @ro75

                  super script von dir

                  Kann du sagen, warum Amazon Echos nicht gehen?

                  Mein Alexa-Echo-Show2 und FireTVStick wird als "true" angezeigt. Die Dot leider nicht

                  Edit: Was sagt den der Status "OK" aus bei jedem Netzwerkgerät

                  Das kannst du selber ausprobieren:
                  per konsole schickst du mal ein 'ping <IP.DES.ECHO.DOT> ab und schaust dir die Antwort an.

                  Es ist denkbar das die Firmware des EchoDot die Antworten auf ICMP Requests blockiert. Das würdest Du da dann sehen (oder auch andere Fehlermeldungen warum das nicht geht)

                  Das OK sagt aus das der Befehl sauber abgearbeitet wurde. Im Falle eines 'ERROR' ist auf deinem System etwas faul was dazu führt das die Pings nicht ausgeführt werden können.

                  A.

                  E Offline
                  E Offline
                  emil70
                  schrieb am zuletzt editiert von
                  #12

                  @asgothian

                  hast Recht, hätte ich auch selbst drauf kommen können

                  "Zeitüberschreitung der Anforderung." kommt

                  gruss emil70

                  iobroker(V9) und Pi-hole läuft über docker (js-controller 6.0.11 und admin v7.1.15) auf einem synology DS918+ mit DSM 7.1.1-42962 Update 6

                  1 Antwort Letzte Antwort
                  0
                  • E Offline
                    E Offline
                    emil70
                    schrieb am zuletzt editiert von
                    #13

                    Hat hier jemand noch eine Idee, wie man

                    1. das man noch einen Datenpunkt bekommen, wieviele Geräte man im Netzwerk hat

                    2. das man noch einen Datenpunkt bekommen, wieviele davon auf "true" stehen

                    gruss emil70

                    iobroker(V9) und Pi-hole läuft über docker (js-controller 6.0.11 und admin v7.1.15) auf einem synology DS918+ mit DSM 7.1.1-42962 Update 6

                    1 Antwort Letzte Antwort
                    0
                    • E Offline
                      E Offline
                      emil70
                      schrieb am zuletzt editiert von
                      #14

                      Habe das jetzt so gelöst. Für Alle die es brauchen können

                      Habe mir dazu extra Datenpunkte angelegt

                      Screenshot 2025-02-04 at 12-14-15 javascript - f5529c8310eb.png

                      Screenshot 2025-02-04 at 12-14-50 javascript - f5529c8310eb.png

                      Screenshot 2025-02-04 at 12-16-58 objects - f5529c8310eb.png

                      gruss emil70

                      iobroker(V9) und Pi-hole läuft über docker (js-controller 6.0.11 und admin v7.1.15) auf einem synology DS918+ mit DSM 7.1.1-42962 Update 6

                      1 Antwort Letzte Antwort
                      0
                      • E Offline
                        E Offline
                        emil70
                        schrieb am zuletzt editiert von emil70
                        #15

                        ich habe aber generell noch eine Frage zu dem script. Ich habe daraus jetzt 3 script gemacht. Da ich Kameras, Lan und Wlan einzeln angezeigt bekommen möchte. Die funktionieren auch Alle soweit

                        ich würde gerne daraus ein script machen. Datenpunkte werden dann auch Alle richtig angelegt. Was ich nicht hinbekommen ist die Ping Abfrage

                        Momentan ist da so meine Einstellungen

                        //Version 1.0.0 - 04.10.2024
                        //Ersteller Ro75.
                        //https://forum.iobroker.net/topic/77249/skript-ping 
                        //Voraussetzungen (Version 1.0.0 getestet mit)
                        //NodeJS: 20.x
                        //Javascript-Adapter: 8.7.6
                        //Admin-Adapter: 7.0.23
                        //JS-Controller: 6.0.11
                        //https://forum.iobroker.net/topic/77249/skript-ping
                         
                        //"normale" Geräte ("Computer, Router, Switch, HUB, NAS, WLAN-Steckdosen, Android-Smartphone, Android-Tablet, etc.")
                        //Amazon Echos, SKY-Geräte und diverse Konsolen (einfach probieren) funktionieren nicht.
                         
                        const ping          = require('ping');          //Im Javascript-Adapter einzutragen (Zusätzliche NPM-Module)
                        const sMainPathKamera        = '0_userdata.0.Netzwerkgeräte-Test.Kamera.';     //zentraler Datenpunkt
                        const sMainPathKameras       = '0_userdata.0.Netzwerkgeräte-Test.Kameras';
                        const sMainPathLan           = '0_userdata.0.Netzwerkgeräte-Test.Lan.';     //zentraler Datenpunkt
                        const sMainPathLangeraete    = '0_userdata.0.Netzwerkgeräte-Test.Lan-Geräte';
                        const sMainPathWlan          = '0_userdata.0.Netzwerkgeräte-Test.Wlan.';     //zentraler Datenpunkt
                        const sMainPathWlangeraete   = '0_userdata.0.Netzwerkgeräte-Test.Wlan-Geräte';
                        
                         
                        //Konfiguration der abzufragenden Geräte. Geräte werden duch "Doppelpunkt" (:) getrennt.
                        //Jedes Geräte besteht aus zwei Werten. Die Werte werden durch Komma (,) getrennt.
                        //Links vom Komma die Bezeichnung und rechts vom Komma die IP-Adresse
                        const cDevicePingKamera   = 'Kamera-Garage,192.168.178.50'; //bitte anpassen
                        const cDevicePingLan      = 'Lan-Geraete,192.168.178.60'; //bitte anpassen
                        const cDevicePingWlan     = 'Wlan-Geraete,192.168.178.70'; //bitte anpassen
                        
                        //Kamera Datenpunkte anlegen
                        function PingInitalisierungKamera(){
                            let sDevice = cDevicePingKamera.split(':');
                            for (let i = 0; i <= sDevice.length-1; i++) {
                                let device_data = sDevice[i].split(',');
                                createState(sMainPathKamera+device_data[0], '', {name: device_data[1],read: true, write: true});
                                createState(sMainPathKamera+device_data[0]+'.Ping.alive', false, {name: 'Pingstatus' ,type: 'boolean', read: true, write: true});
                                createState(sMainPathKamera+device_data[0]+'.Ping.time', 0, {name: 'Zeit' ,type: 'number', read: true, write: true, unit: 'ms'});
                                createState(sMainPathKamera+device_data[0]+'.Ping.status', '', {name: 'Status' ,type: 'string', read: true, write: true});
                        		createState(sMainPathKameras, 0, {name: 'Onlinestatus' ,type: 'number', read: true, write: true});
                            }
                        }
                        
                        //Lan Datenpunkte anlegen
                        function PingInitalisierungLan(){
                            let sDevice = cDevicePingLan.split(':');
                            for (let i = 0; i <= sDevice.length-1; i++) {
                                let device_data = sDevice[i].split(',');
                                createState(sMainPathLan+device_data[0], '', {name: device_data[1],read: true, write: true});
                                createState(sMainPathLan+device_data[0]+'.Ping.alive', false, {name: 'Pingstatus' ,type: 'boolean', read: true, write: true});
                                createState(sMainPathLan+device_data[0]+'.Ping.time', 0, {name: 'Zeit' ,type: 'number', read: true, write: true, unit: 'ms'});
                                createState(sMainPathLan+device_data[0]+'.Ping.status', '', {name: 'Status' ,type: 'string', read: true, write: true});
                        		createState(sMainPathLangeraete, 0, {name: 'Onlinestatus' ,type: 'number', read: true, write: true});
                            }
                        }
                        
                        //Wlan Datenpunkte anlegen
                        function PingInitalisierungWlan(){
                            let sDevice = cDevicePingWlan.split(':');
                            for (let i = 0; i <= sDevice.length-1; i++) {
                                let device_data = sDevice[i].split(',');
                                createState(sMainPathWlan +device_data[0], '', {name: device_data[1],read: true, write: true});
                                createState(sMainPathWlan +device_data[0]+'.Ping.alive', false, {name: 'Pingstatus' ,type: 'boolean', read: true, write: true});
                                createState(sMainPathWlan +device_data[0]+'.Ping.time', 0, {name: 'Zeit' ,type: 'number', read: true, write: true, unit: 'ms'});
                                createState(sMainPathWlan +device_data[0]+'.Ping.status', '', {name: 'Status' ,type: 'string', read: true, write: true});
                        		createState(sMainPathWlangeraete, 0, {name: 'Onlinestatus' ,type: 'number', read: true, write: true});
                            }
                        }
                        
                        
                        //START
                        PingInitalisierungKamera();
                         
                        async function pingHost(host,sDesc) {
                            try {
                                const res = await ping.promise.probe(host, {timeout: 2, deadline: 2, packetSize: 16});
                                setState(sMainPathKamera+sDesc+'.Ping.alive', JSON.parse(JSON.stringify(res)).alive, true);
                                setState(sMainPathKamera+sDesc+'.Ping.time', parseFloat(JSON.parse(JSON.stringify(res)).time), true);
                                setState(sMainPathKamera+sDesc+'.Ping.status', 'OK', true);
                            } catch (error) {
                                setState(sMainPathKamera+sDesc+'.Ping.status', 'ERROR', true);
                            }
                        }
                        
                        PingInitalisierungLan();
                         
                        async function pingHost(host,sDesc) {
                            try {
                                const res = await ping.promise.probe(host, {timeout: 2, deadline: 2, packetSize: 16});
                                setState(sMainPathLan+sDesc+'.Ping.alive', JSON.parse(JSON.stringify(res)).alive, true);
                                setState(sMainPathLan+sDesc+'.Ping.time', parseFloat(JSON.parse(JSON.stringify(res)).time), true);
                                setState(sMainPathLan+sDesc+'.Ping.status', 'OK', true);
                            } catch (error) {
                                setState(sMainPathLan+sDesc+'.Ping.status', 'ERROR', true);
                            }
                        }
                        
                        PingInitalisierungWlan();
                         
                        async function pingHost(host,sDesc) {
                            try {
                                const res = await ping.promise.probe(host, {timeout: 2, deadline: 2, packetSize: 16});
                                setState(sMainPathWlan+sDesc+'.Ping.alive', JSON.parse(JSON.stringify(res)).alive, true);
                                setState(sMainPathWlan+sDesc+'.Ping.time', parseFloat(JSON.parse(JSON.stringify(res)).time), true);
                                setState(sMainPathWlan+sDesc+'.Ping.status', 'OK', true);
                            } catch (error) {
                                setState(sMainPathWlan+sDesc+'.Ping.status', 'ERROR', true);
                            }
                        }
                        
                        
                        //Ping aller 10 Sekunden - kann angepasst werden - kleinerer Wert nicht empfohlen
                        //damit das Intervall (wenn zu niedrig) nicht "gesprengt" wird: Schleife sperren und am Ende wieder freigeben
                        let bPingSperreKamera = false;
                        schedule('*/20 * * * * *', async function StartPing() {
                            if (bPingSperreKamera == false) {
                                bPingSperreKamera = true;
                                let sDevice = cDevicePingKamera.split(':');
                                for (let i = 0; i <= sDevice.length-1; i++) {
                                    await pingHost(sDevice[i].split(',')[1],sDevice[i].split(',')[0]);
                                }
                                bPingSperreKamera = false;
                            }
                        });
                        
                        let bPingSperreLan = false;
                        schedule('*/30 * * * * *', async function StartPing() {
                            if (bPingSperreLan == false) {
                                bPingSperreLan = true;
                                let sDevice = cDevicePingLan.split(':');
                                for (let i = 0; i <= sDevice.length-1; i++) {
                                    await pingHost(sDevice[i].split(',')[1],sDevice[i].split(',')[0]);
                                }
                                bPingSperreLan= false;
                            }
                        });
                        
                        //Ping aller 10 Sekunden - kann angepasst werden - kleinerer Wert nicht empfohlen
                        //damit das Intervall (wenn zu niedrig) nicht "gesprengt" wird: Schleife sperren und am Ende wieder freigeben
                        let bPingSperreWlan = false;
                        schedule('*/40 * * * * *', async function StartPing() {
                            if (bPingSperreWlan == false) {
                                bPingSperreWlan = true;
                                let sDevice = cDevicePingWlan.split(':');
                                for (let i = 0; i <= sDevice.length-1; i++) {
                                    await pingHost(sDevice[i].split(',')[1],sDevice[i].split(',')[0]);
                                }
                                bPingSperreWlan = false;
                            }
                        });
                        

                        der Part ist so nicht richtig. Da bräuchte ich Hilfe

                        //START
                        PingInitalisierungKamera();
                         
                        async function pingHost(host,sDesc) {
                            try {
                                const res = await ping.promise.probe(host, {timeout: 2, deadline: 2, packetSize: 16});
                                setState(sMainPathKamera+sDesc+'.Ping.alive', JSON.parse(JSON.stringify(res)).alive, true);
                                setState(sMainPathKamera+sDesc+'.Ping.time', parseFloat(JSON.parse(JSON.stringify(res)).time), true);
                                setState(sMainPathKamera+sDesc+'.Ping.status', 'OK', true);
                            } catch (error) {
                                setState(sMainPathKamera+sDesc+'.Ping.status', 'ERROR', true);
                            }
                        }
                        
                        PingInitalisierungLan();
                         
                        async function pingHost(host,sDesc) {
                            try {
                                const res = await ping.promise.probe(host, {timeout: 2, deadline: 2, packetSize: 16});
                                setState(sMainPathLan+sDesc+'.Ping.alive', JSON.parse(JSON.stringify(res)).alive, true);
                                setState(sMainPathLan+sDesc+'.Ping.time', parseFloat(JSON.parse(JSON.stringify(res)).time), true);
                                setState(sMainPathLan+sDesc+'.Ping.status', 'OK', true);
                            } catch (error) {
                                setState(sMainPathLan+sDesc+'.Ping.status', 'ERROR', true);
                            }
                        }
                        
                        PingInitalisierungWlan();
                         
                        async function pingHost(host,sDesc) {
                            try {
                                const res = await ping.promise.probe(host, {timeout: 2, deadline: 2, packetSize: 16});
                                setState(sMainPathWlan+sDesc+'.Ping.alive', JSON.parse(JSON.stringify(res)).alive, true);
                                setState(sMainPathWlan+sDesc+'.Ping.time', parseFloat(JSON.parse(JSON.stringify(res)).time), true);
                                setState(sMainPathWlan+sDesc+'.Ping.status', 'OK', true);
                            } catch (error) {
                                setState(sMainPathWlan+sDesc+'.Ping.status', 'ERROR', true);
                            }
                        }
                        
                        
                        //Ping aller 10 Sekunden - kann angepasst werden - kleinerer Wert nicht empfohlen
                        //damit das Intervall (wenn zu niedrig) nicht "gesprengt" wird: Schleife sperren und am Ende wieder freigeben
                        let bPingSperreKamera = false;
                        schedule('*/20 * * * * *', async function StartPing() {
                            if (bPingSperreKamera == false) {
                                bPingSperreKamera = true;
                                let sDevice = cDevicePingKamera.split(':');
                                for (let i = 0; i <= sDevice.length-1; i++) {
                                    await pingHost(sDevice[i].split(',')[1],sDevice[i].split(',')[0]);
                                }
                                bPingSperreKamera = false;
                            }
                        });
                        
                        let bPingSperreLan = false;
                        schedule('*/30 * * * * *', async function StartPing() {
                            if (bPingSperreLan == false) {
                                bPingSperreLan = true;
                                let sDevice = cDevicePingLan.split(':');
                                for (let i = 0; i <= sDevice.length-1; i++) {
                                    await pingHost(sDevice[i].split(',')[1],sDevice[i].split(',')[0]);
                                }
                                bPingSperreLan= false;
                            }
                        });
                        
                        //Ping aller 10 Sekunden - kann angepasst werden - kleinerer Wert nicht empfohlen
                        //damit das Intervall (wenn zu niedrig) nicht "gesprengt" wird: Schleife sperren und am Ende wieder freigeben
                        let bPingSperreWlan = false;
                        schedule('*/40 * * * * *', async function StartPing() {
                            if (bPingSperreWlan == false) {
                                bPingSperreWlan = true;
                                let sDevice = cDevicePingWlan.split(':');
                                for (let i = 0; i <= sDevice.length-1; i++) {
                                    await pingHost(sDevice[i].split(',')[1],sDevice[i].split(',')[0]);
                                }
                                bPingSperreWlan = false;
                            }
                        });
                        

                        Edit: nach der ersten Pingabfrage kommt dann das

                        javascript.0	12:35:20.027	warn	at async Object.StartPing (script.js.common.Netzwerkstatus.Test1:121:13)
                        javascript.0	12:35:20.028	warn	at pingHost (script.js.common.Netzwerkstatus.Test1:105:9)
                        javascript.0	12:35:20.028	warn	at async Object.StartPing (script.js.common.Netzwerkstatus.Test1:121:13)
                        javascript.0	12:35:20.029	warn	at pingHost (script.js.common.Netzwerkstatus.Test1:106:9)
                        javascript.0	12:35:20.029	warn	at async Object.StartPing (script.js.common.Netzwerkstatus.Test1:121:13)
                        javascript.0	12:35:20.051	warn	at pingHost (script.js.common.Netzwerkstatus.Test1:104:9)
                        javascript.0	12:35:20.051	warn	at async Object.StartPing (script.js.common.Netzwerkstatus.Test1:121:13)
                        javascript.0	12:35:20.053	warn	at pingHost (script.js.common.Netzwerkstatus.Test1:105:9)
                        javascript.0	12:35:20.053	warn	at async Object.StartPing (script.js.common.Netzwerkstatus.Test1:121:13)
                        javascript.0	12:35:20.054	warn	at pingHost (script.js.common.Netzwerkstatus.Test1:106:9)
                        javascript.0	12:35:20.054	warn	at async Object.StartPing (script.js.common.Netzwerkstatus.Test1:121:13)
                        javascript.0	12:35:20.077	warn	at pingHost (script.js.common.Netzwerkstatus.Test1:104:9)
                        javascript.0	12:35:20.078	warn	at async Object.StartPing (script.js.common.Netzwerkstatus.Test1:121:13)
                        javascript.0	12:35:20.079	warn	at pingHost (script.js.common.Netzwerkstatus.Test1:105:9)
                        javascript.0	12:35:20.080	warn	at async Object.StartPing (script.js.common.Netzwerkstatus.Test1:121:13)
                        javascript.0	12:35:20.081	warn	at pingHost (script.js.common.Netzwerkstatus.Test1:106:9)
                        javascript.0	12:35:20.081	warn	at async Object.StartPing (script.js.common.Netzwerkstatus.Test1:121:13)
                        javascript.0	12:35:20.102	warn	at pingHost (script.js.common.Netzwerkstatus.Test1:104:9)
                        javascript.0	12:35:20.103	warn	at async Object.StartPing (script.js.common.Netzwerkstatus.Test1:121:13)
                        javascript.0	12:35:20.104	warn	at pingHost (script.js.common.Netzwerkstatus.Test1:105:9)
                        javascript.0	12:35:20.104	warn	at async Object.StartPing (script.js.common.Netzwerkstatus.Test1:121:13)
                        javascript.0	12:35:20.106	warn	at pingHost (script.js.common.Netzwerkstatus.Test1:106:9)
                        javascript.0	12:35:20.106	warn	at async Object.StartPing (script.js.common.Netzwerkstatus.Test1:121:13)
                        javascript.0	12:35:20.136	warn	at pingHost (script.js.common.Netzwerkstatus.Test1:104:9)
                        javascript.0	12:35:20.137	warn	at async Object.StartPing (script.js.common.Netzwerkstatus.Test1:121:13)
                        javascript.0	12:35:20.138	warn	at pingHost (script.js.common.Netzwerkstatus.Test1:105:9)
                        javascript.0	12:35:20.138	warn	at async Object.StartPing (script.js.common.Netzwerkstatus.Test1:121:13)
                        javascript.0	12:35:20.139	warn	at pingHost (script.js.common.Netzwerkstatus.Test1:106:9)
                        javascript.0	12:35:20.140	warn	at async Object.StartPing (script.js.common.Netzwerkstatus.Test1:121:13)
                        javascript.0	12:35:20.197	warn	at pingHost (script.js.common.Netzwerkstatus.Test1:104:9)
                        javascript.0	12:35:20.197	warn	at async Object.StartPing (script.js.common.Netzwerkstatus.Test1:121:13)
                        javascript.0	12:35:20.198	warn	at pingHost (script.js.common.Netzwerkstatus.Test1:105:9)
                        javascript.0	12:35:20.198	warn	at async Object.StartPing (script.js.common.Netzwerkstatus.Test1:121:13)
                        javascript.0	12:35:20.199	warn	at pingHost (script.js.common.Netzwerkstatus.Test1:106:9)
                        javascript.0	12:35:20.200	warn	at async Object.StartPing (script.js.common.Netzwerkstatus.Test1:121:13)
                        

                        gruss emil70

                        iobroker(V9) und Pi-hole läuft über docker (js-controller 6.0.11 und admin v7.1.15) auf einem synology DS918+ mit DSM 7.1.1-42962 Update 6

                        1 Antwort Letzte Antwort
                        0
                        Antworten
                        • In einem neuen Thema antworten
                        Anmelden zum Antworten
                        • Älteste zuerst
                        • Neuste zuerst
                        • Meiste Stimmen


                        Support us

                        ioBroker
                        Community Adapters
                        Donate

                        481

                        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