Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. [gelöst] Speedtest-Skript liefert falsche Werte

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    [gelöst] Speedtest-Skript liefert falsche Werte

    This topic has been deleted. Only users with topic management privileges can see it.
    • Thomas Braun
      Thomas Braun Most Active last edited by Thomas Braun

      [Edit:] Ursache war eine sterbende SSD. Mit frischer Hardware funktioniert wieder alles.

      @SKB

      Ich habe seit vorgestern urplötzlich falsche Werte mit dem speedtest-Skript.
      Wenn ich den Speedtest im Terminal ausführe bekomme ich plausible Werte, im ioBroker kommen aber in den Datenpunkten entweder gar keine oder deutlich zu niedrige Werte an. Hat sich beim JSON, das vom speedtest ausgespuckt wird vielleicht was getan?

      Skript:

      /*
      * @copyright 2020 Stephan Kreyenborg <stephan@kreyenborg.koeln>
      *
      * @author 2020 Stephan Kreyenborg <stephan@kreyenborg.koeln>
      *
      * Dieses Skript dient zur freien Verwendung in ioBroker zur Überprüfung Deiner Internetgeschwindkeit mit Hilfe von Speedtest.
      * Jegliche Verantwortung liegt beim Benutzer. Das Skript wurde unter Berücksichtigung der bestmöglichen Nutzung
      * und Performance entwickelt.
      * Der Entwickler versichert, das keine böswilligen Systemeingriffe im originalen Skript vorhanden sind.
      *
      * Sollte das Skript wider Erwarten nicht korrekt funktionieren, so hast Du jederzeit die Möglichkeit, Dich auf
      * https://www.kreyenborg.koeln
      * für Unterstützung zu melden. Jedes Skript besitzt seine eigene Kommentarseite, auf der,
      * nach zeitlicher Möglichkeit des Autors, Hilfe angeboten wird. Ein Anrecht hierauf besteht nicht!
      *
      * Ansprüche gegenüber Dritten bestehen nicht.
      *
      * Skript Name: Speedtest
      * Skript Version: 1.3
      * Erstell-Datum: 29. November 2021
      *
      */
      
      // Datenpunkte neu erstellen
      var ueberschreiben = false;
      
      // Hauptdatenpunkt unterhalb javascript
      var datenpunkt = "Speedtest.";
      
      // Favorisierter Server
      // Liste: https://www.speedtest.net/speedtest-servers.php
      // var fav_server = 28602;
      // var fav_server = 6670; // speedtest21.hotspot.koeln
      var fav_server = 6601; // speedtest11.hotspot.koeln
      // var fav_server = 17392; // myLoc managed IT AG - Dusseldorf
      // var fav_server = 28624; // Händle & Korte GmbH - Dusseldorf
      // var fav_server = 35154; // Contabo - Dusseldorf
      // var fav_server = 28439; // CoreRoute - Dusseldorf
      
      // Speedtest Objekte
      var objekt = ["JSON_Output",
      "Ergebnisse.Ping",
      "Ergebnisse.Jitter",
      "Ergebnisse.Download_MBit",
      "Ergebnisse.Upload_MBit",
      "Ergebnisse.Download_MB",
      "Ergebnisse.Upload_MB",
      "Ergebnisse.OriginalDownload",
      "Ergebnisse.OriginalUpload",
      "ISP",
      "IP",
      "Ergebnisse.URL",
      "Ergebnisse.ID",
      "Test.Server.ServerID",
      "Test.Server.ServerIP",
      "Test.Server.Name",
      "Test.Server.Stadt",
      "Test.Server.Land",
      "Test.Server.Adresse",
      "Test.Daten.Download",
      "Test.Daten.Upload",
      "Test.Daten.OriginalDownload",
      "Test.Daten.OriginalUpload",
      "Test.Daten.DauerDownload",
      "Test.Daten.DauerUpload",
      "Test.Daten.Letzter_Speedtest"
      ];
      
      // Beschreibung der Objekte
      var beschreibung = ["JSON Ausgabe der Konsole",
      "Ping in ms",
      "Jitter in ms",
      "Download Geschwindigkeit in MBit/s",
      "Upload Geschwindigkeit in MBit/s",
      "Download Geschwindigkeit in MB/s",
      "Upload Geschwindigkeit in MB/s",
      "Download Geschwindigkeit in Byte/s",
      "Upload Geschwindigkeit in Byte/s",
      "Internet Service Provider",
      "externe IP",
      "Adresse der Ergebnisse",
      "ID der Ergebnisse",
      "ID des getesteten Servers",
      "IP des getesteten Servers",
      "Anbieter des getesteten Servers",
      "Stadt des getesteten Servers",
      "Land des getesteten Servers",
      "URL des getesteten Servers",
      "Download Daten in MB",
      "Upload Daten in MB",
      "Download Daten in Byte",
      "Upload Daten in Byte",
      "Dauer des Download Test",
      "Dauer des Upload Test",
      "Letzter Speedtest"
      ];
      
      // Einheiten der Objekte
      var einheiten = ["",
      "ms",
      "ms",
      "MBit/s",
      "MBit/s",
      "MB/s",
      "MB/s",
      "Byte/s",
      "Byte/s",
      "",
      "",
      "",
      "",
      "",
      "",
      "",
      "",
      "",
      "",
      "MB",
      "MB",
      "Byte",
      "Byte",
      "s",
      "s",
      ""
      ];
      
      // Typen der Objekte
      var typen = ["string",
      "number",
      "number",
      "number",
      "number",
      "number",
      "number",
      "number",
      "number",
      "string",
      "string",
      "string",
      "string",
      "number",
      "string",
      "string",
      "string",
      "string",
      "string",
      "number",
      "number",
      "number",
      "number",
      "number",
      "number",
      "string"
      ];
      
      // Rollen der Objekte
      var rolle = ["json",
      "value",
      "value",
      "value",
      "value",
      "value",
      "value",
      "value",
      "value",
      "text",
      "text",
      "text",
      "text",
      "value",
      "text",
      "text",
      "text",
      "text",
      "text",
      "value",
      "value",
      "value",
      "value",
      "value",
      "value",
      "text"
      ];
      
      // Schreibe Werte des JSON String in ein Array
      function generiere_array(json_array) {
      var j = JSON.parse(json_array);
      var array_werte = [json_array,
      j.ping.latency,
      j.ping.jitter,
      parseFloat((j.download.bandwidth / 125000).toFixed(2)),
      parseFloat((j.upload.bandwidth / 125000).toFixed(2)),
      parseFloat((j.download.bandwidth / (1024 * 1024)).toFixed(2)),
      parseFloat((j.upload.bandwidth / (1024 * 1024)).toFixed(2)),
      j.download.bandwidth,
      j.upload.bandwidth,
      j.isp,
      j.interface.externalIp,
      j.result.url,
      j.result.id,
      j.server.id,
      j.server.ip,
      j.server.name,
      j.server.location,
      j.server.country,
      j.server.host,
      parseFloat((j.download.bytes / (1024 * 1024)).toFixed(2)),
      parseFloat((j.upload.bytes / (1024 * 1024)).toFixed(2)),
      j.download.bytes,
      j.upload.bytes,
      parseFloat((j.download.elapsed / 1000).toFixed(2)),
      parseFloat((j.upload.elapsed / 1000).toFixed(2)),
      hole_datum()
      ];
      return array_werte;
      }
      
      function speedtest() {
      // temporäre Variable für das Array
      var tmp_json;
      // Kommando für den Speedtest
      var kommando = "/usr/bin/speedtest -f json --accept-license --accept-gdpr";
      if (fav_server > 0) {
      kommando = kommando + " -s " + fav_server;
      // log("Speedtest mit Server " + fav_server + " gestartet! Der Test dauert zwischen 10 - 20 Sekunden!");
      } else {
      // log("Speedtest gestartet! Der Test dauert zwischen 10 - 20 Sekunden!");
      }
      exec(kommando,
      function (error, stdout) {
      if (error) {
      log('Speedtest konnte nicht ausgeführt werden! ' + error, 'error');
      return;
      } else {
      tmp_json = generiere_array(stdout);
      aktualisiere_datenpunkt(tmp_json);
      // log('Speedtest durchgeführt. Ergebnisse: Download: ' + tmp_json[3] + ' MBit/s | Upload: ' + tmp_json[4] + ' MBit/s | Ping: ' + tmp_json[1] + 'ms');
      }
      });
      }
      
      function aktualisiere_datenpunkt(werte) {
      for (let i = 0; i < objekt.length; i++) {
      setState(datenpunkt + objekt[i], werte[i], true);
      }
      }
      
      // Erstelle die benötigten Datenpunkte
      function datenpunkte_erstellen() {
      for (var i = 0; i < objekt.length; i++) {
      createState(datenpunkt + objekt[i], "", ueberschreiben, {
      name: beschreibung[i],
      desc: beschreibung[i],
      type: typen[i],
      role: rolle[i],
      unit: einheiten[i]
      });
      }
      
      // Alle Datenpunkte erstellt. Führe ersten Speedtest aus!
      log('Speedtest: Datenpunkte erstellt! Erster Speedtest wird in 180 Sekunden ausgeführt!');
      setTimeout(speedtest, 1800000);
      }
      
      // Datum
      function hole_datum() {
      let datum = new Date();
      let tag = '0' + datum.getDate();
      let monat = '0' + (datum.getMonth() + 1);
      let jahr = datum.getFullYear();
      let stunde = '0' + datum.getHours();
      let minute = '0' + datum.getMinutes();
      let sekunde = '0' + datum.getSeconds();
      return tag.substr(-2) + '.' + monat.substr(-2) + '.' + jahr + ' ' + stunde.substr(-2) + ':' + minute.substr(-2) + ':' + sekunde.substr(-2);
      }
      
      function speedtest_erster_start() {
      log("Speedtest: Erster Start des Skriptes! Datenpunkte werden erstellt!");
      // Datenpunkte werden erstellt
      datenpunkte_erstellen();
      }
      
      // Erster Start und Initialisierung
      speedtest_erster_start();
      
      // Alle 30 Minuten einen Speedtest ausführen
      schedule('23 * * * *', speedtest);
      
      

      Der Graph dazu schaut etwas gestutzt aus...
      93844ce0-5fa6-4bcf-a44b-52fc6014ba81-grafik.png

      SKB 1 Reply Last reply Reply Quote 0
      • SKB
        SKB Developer Most Active @Thomas Braun last edited by

        @thomas-braun Könnte natürlich sein. Schaue ich mir an.

        Thomas Braun 2 Replies Last reply Reply Quote 0
        • Thomas Braun
          Thomas Braun Most Active @SKB last edited by Thomas Braun

          @skb

          Danke. Was mich auch stutzig macht ist das Log zum Skript.

          2024-11-20 19:56:39.119  - info: javascript.0 (1205) script.js.common.speedtest: Speedtest: Erster Start des Skriptes! Datenpunkte werden erstellt!
          2024-11-20 19:56:39.121  - info: javascript.0 (1205) script.js.common.speedtest: Speedtest: Datenpunkte erstellt! Erster Speedtest wird in 180 Sekunden ausgeführt!
          2024-11-20 19:56:39.127  - info: javascript.0 (1205) script.js.common.speedtest: registered 0 subscriptions, 1 schedule, 0 messages, 0 logs and 0 file subscriptions
          

          Die 180 Sekunden sind ja um, aber ein speedtest wurde nicht geloggt.

          Edit: Okay, das ist wohl noch auskommentiert. Wollte ich eigentlich wieder scharf schalten...

          1 Reply Last reply Reply Quote 0
          • Thomas Braun
            Thomas Braun Most Active @SKB last edited by

            @skb

            Ich vermute, mein Fav-Server hat ein Problem. Obwohl ich das natürlich auch mal umgestellt hatte. Aber gerade läuft wieder alles wie gewohnt:

            2024-11-20 21:07:26.515  - info: javascript.0 (1205) script.js.common.speedtest: Speedtest mit Server 35154 gestartet! Der Test dauert zwischen 10 - 20 Sekunden!
            2024-11-20 21:07:40.742  - info: javascript.0 (1205) script.js.common.speedtest: Speedtest durchgeführt. Ergebnisse: Download: 927.05 MBit/s | Upload: 49.04 MBit/s | Ping: 9.423ms
            2024-11-20 21:23:00.032  - info: javascript.0 (1205) script.js.common.speedtest: Speedtest mit Server 35154 gestartet! Der Test dauert zwischen 10 - 20 Sekunden!
            2024-11-20 21:23:23.030  - info: javascript.0 (1205) script.js.common.speedtest: Speedtest durchgeführt. Ergebnisse: Download: 926.79 MBit/s | Upload: 48.29 MBit/s | Ping: 9.158ms
            
            
            SKB 1 Reply Last reply Reply Quote 0
            • SKB
              SKB Developer Most Active @Thomas Braun last edited by

              @thomas-braun Habe bei mir geschaut - die Werte passen noch genau. Scheint aber wohl an deinem Fav-Server zu liegen 😉

              Thomas Braun 1 Reply Last reply Reply Quote 0
              • Thomas Braun
                Thomas Braun Most Active @SKB last edited by Thomas Braun

                @skb

                Ja, hat sich irgendwie wieder gefangen, die fav_server hatte ich aber auch mal durchprobiert und z. T. ganz weggelassen. So ganz erklären kann ich mir die 'Delle' im Graphen jedoch nicht.

                Edit: Ich denke, das hat mit einer sterbenden SSD zu tun. Werde die Kiste am Wochenende mal flugs neu aufsetzen.

                SKB 1 Reply Last reply Reply Quote 0
                • SKB
                  SKB Developer Most Active @Thomas Braun last edited by

                  @thomas-braun Wenns ja dann an einer defekten SSD liegen könnte, könnte man das Thema ja auf "gelöst" setzen 😉

                  1 Reply Last reply Reply Quote 0
                  • First post
                    Last post

                  Support us

                  ioBroker
                  Community Adapters
                  Donate

                  682
                  Online

                  31.7k
                  Users

                  79.6k
                  Topics

                  1.3m
                  Posts

                  2
                  7
                  269
                  Loading More Posts
                  • Oldest to Newest
                  • Newest to Oldest
                  • Most Votes
                  Reply
                  • Reply as topic
                  Log in to reply
                  Community
                  Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                  The ioBroker Community 2014-2023
                  logo