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

  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Script für einen SpeedTest über speedtest.net

NEWS

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

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    1.9k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    15
    1
    2.3k

Script für einen SpeedTest über speedtest.net

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
javascript
177 Beiträge 57 Kommentatoren 42.8k Aufrufe 39 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.
  • P pix

    Hallo,

    es nervt mittlerweile, dass man die alten Skripte nicht mehr einfach verwenden/kopieren kann.
    Das neue Forum hat mich bisher mehr Zeit gekostet, als es gespart hat.

    @Kueppert Du kannst natürlich nix dafür. Hier der Code vom genannten Post nochmal zusammenkopiert, falsche Zeichen entfernt und durch den Beautifier gejagt:

    /* Speed-Test
    SpeedTest mit Ausgabe von Down- / Uploadgeschwindigkeit und Ping
    http://forum.iobroker.net/viewtopic.php?f=21&t=4170
    Erstellt 10.11.2016 by Cybertron
    angepasst 14.03.2017 by Pix
    20.03.2017 Unit ms für Datenpunkt ping (danke 0018)
    Installation:
    npm install --global speed-test
    Aufruf:
    speed-test --json --verbose
    Beispiel-Ausgabe:
    {"ping":118,"download":2.2,"upload":2.2,"data":{"speeds":{"download":2.179,"upload":2.209,"originalDownload":239941,"originalUpload":242389},
    "client":{"ip":"xxx.xxx.xxx.xxx","lat":51.2993,"lon":9.491,"isp":"Deutsche Telekom","isprating":3,"rating":0,"ispdlavg":13.86,"ispulavg":3.108},
    "server":{"host":"speedtest.hillcom.de","lat":50.7511,"lon":9.2711,"location":"Alsfeld","country":"Germany","cc":"DE","sponsor":"HillCom Solutions",
    "distance":62.87,"distanceMi":39.06,"ping":117.8,"id":"6599"}}}
    */
    var logging = true;
    var instanz = 'javascript.' + instance + '.';
    var pfad = 'Speed-Test.';
    var cronStr = "29,59 * * * *";
    
    function createStates() {
        // Allgemein
        createState(pfad + 'json', {
            name: 'JSON',
            desc: 'JSON Ausgabe',
            type: 'string',
            role: 'json'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'json erstellt');
        });
        createState(pfad + 'ping', {
            name: 'Ping',
            desc: 'Ping',
            type: 'number',
            unit: 'ms',
            role: 'value'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'ping erstellt');
        });
    
        createState(pfad + 'forceRefresh', {
            name: 'aktualisieren',
            desc: 'Werte neu einlesen',
            type: 'boolean',
            def: false,
            role: 'indicator'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'forceRefresh erstellt');
        });
    
        // Speed
        createState(pfad + 'data.speeds.download', {
            name: 'Download',
            desc: 'Downloadgeschwindigkeit (Mbit/s)',
            type: 'number',
            unit: 'Mbit/s',
            role: 'value'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'data.speeds.download erstellt');
        });
        createState(pfad + 'data.speeds.upload', {
            name: 'Upload',
            desc: 'Uploadgeschwindigkeit (Mbit/s)',
            type: 'number',
            unit: 'Mbit/s',
            role: 'value'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'data.speeds.upload erstellt');
        });
        createState(pfad + 'data.speeds.orginalDownload', {
            name: 'OrginalDownload',
            desc: 'Downloadgeschwindigkeit (bit/s)',
            type: 'number',
            unit: 'bit/s',
            role: 'value'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'data.speeds.original Download erstellt');
        });
        createState(pfad + 'data.speeds.orginalUpload', {
            name: 'OrginalUpload',
            desc: 'Uploadgeschwindigkeit (bit/s)',
            type: 'number',
            unit: 'bit/s',
            role: 'value'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'data.speeds.originalUpload erstellt');
        });
        // Client
        createState(pfad + 'data.client.ip', {
            name: 'IP',
            desc: 'Öffentliche IP-Adresse',
            type: 'string',
            role: 'text'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'data.client.ip erstellt');
        });
        createState(pfad + 'data.client.lat', {
            name: 'Latitude',
            desc: 'Latidude',
            type: 'number', // ##########################
            unit: '°',
            role: 'value.gps.latitude'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'data.client.lat erstellt');
        });
        createState(pfad + 'data.client.lon', {
            name: 'Longitude',
            desc: 'Longitude',
            type: 'number', // ##########################
            unit: '°',
            role: 'value.gps.longitude'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'data.client.lomg erstellt');
        });
        createState(pfad + 'data.client.isp', {
            name: 'ISP',
            desc: 'Internet-Service-provider',
            type: 'string',
            role: 'text'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'data.client.isp erstellt');
        });
    
        createState(pfad + 'data.client.isprating', {
            name: 'ISP-Rating',
            desc: 'ISP-Rating',
            type: 'number',
            role: 'value'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'data.client.isprating erstellt');
        });
    
        createState(pfad + 'data.client.rating', {
            name: 'Rating',
            desc: 'Rating',
            type: 'number',
            role: 'value'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'data.client.rating erstellt');
        });
    
        createState(pfad + 'data.client.ispdlavg', {
            name: 'ISP-DL-AVG',
            desc: 'ISPDLAVG',
            type: 'number',
            unit: 'Mbit/s',
            role: 'value'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'data.client.ispdlavg erstellt');
        });
    
        createState(pfad + 'data.client.ispulavg', {
            name: 'ISP-UL-AVG',
            desc: 'ISPULAVG',
            type: 'number',
            unit: 'Mbit/s',
            role: 'value'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'data.client.ispulavg erstellt');
        });
    
        // Server
        createState(pfad + 'data.server.host', {
            name: 'Host',
            desc: 'Hostname des Servers',
            type: 'string',
            role: 'text'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'data.server.host erstellt');
        });
    
    
        createState(pfad + 'data.server.lat', {
            name: 'Server-Latitude',
            desc: 'Latitude des Serverstandortes',
            type: 'number', // ##########################
            unit: '°',
            role: 'value.gps.latitude'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'data.server.lat erstellt');
        });
    
        createState(pfad + 'data.server.lon', {
            name: 'Server-Longitude',
            desc: 'Longitude des Serverstandortes',
            type: 'number', // ##########################
            unit: '°',
            role: 'value.gps.longitude'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'data.server.lon erstellt');
        });
    
        createState(pfad + 'data.server.location', {
            name: 'Server-Location',
            desc: 'Server-Standort',
            type: 'string',
            role: 'text.city'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'data.server.location erstellt');
        });
    
        createState(pfad + 'data.server.country', {
            name: 'Server-Country',
            desc: 'Land',
            type: 'string',
            role: 'text.country'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'data.server.country erstellt');
        });
    
        createState(pfad + 'data.server.cc', {
            name: 'Server-CC',
            desc: 'Länderkürzel',
            type: 'string',
            role: 'text'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'data.server.cc erstellt');
        });
    
        createState(pfad + 'data.server.sponsor', {
            name: 'Server-Sponsor',
            desc: 'Sponsor des Servers',
            type: 'string',
            role: 'text'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'data.server.sponsor erstellt');
        });
    
        createState(pfad + 'data.server.distance', {
            name: 'DistanzToServer',
            desc: 'Distanz zum Server in km',
            type: 'number',
            unit: 'km',
            role: 'value'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'data.server.distance erstellt');
        });
    
        createState(pfad + 'data.server.distanceMi', {
            name: 'DistanzToServerMeilen',
            desc: 'Distanz des Servers im Meilen',
            type: 'number',
            unit: 'Meilen',
            role: 'value'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'data.server.distanceMi erstellt');
        });
    
        createState(pfad + 'data.server.ping', {
            name: 'Server-Ping',
            desc: 'Ping zum Server',
            type: 'number',
            unit: 'ms',
            role: 'value'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'data.server.ping erstellt');
        });
    
        createState(pfad + 'data.server.id', {
            name: 'Server-ID',
            desc: 'Server ID',
            type: 'number',
            role: 'value'
        }, function() {
            if (logging) log('Objekt ' + instanz + pfad + 'data.server.id erstellt');
        });
    
    }
    
    function SpeedTest() {
        exec("speed-test --json --verbose", function(err, stdout, stderr) {
            if (err) {
                log(stderr, 'error');
                log('Speedtest Daten konnten nicht abgefragt werden', 'error');
                return;
            }
            writeDP(stdout);
        });
    }
    
    function writeDP(jsonstring) {
        var objects = JSON.parse(jsonstring);
    
        var jsonStr = jsonstring;
        //log (jsonStr);
    
        var ping = objects.ping;
        var download = objects.download;
        var upload = objects.upload;
        //log ('Ping =' + ping);
        //log ('Download = ' + download);
        //log ('Upload = ' + upload);
        var Speed_Download = objects.data.speeds.download;
        var Speed_Upload = objects.data.speeds.upload;
        var Speed_OriginalDownload = objects.data.speeds.originalDownload;
        var Speed_OriginalUpload = objects.data.speeds.originalUpload;
        //log ('Speed_Download = ' + Speed_Download);
        //log ('Speed_Upload = ' + Speed_Upload);
        //log ('OriginalDownload = ' + Speed_OriginalDownload);
        //log ('OriginalUpload = ' + Speed_OriginalUpload);
        var Client_IP = objects.data.client.ip;
        var Client_lat = objects.data.client.lat;
        var Client_lon = objects.data.client.lon;
        var Client_isp = objects.data.client.isp;
        var Client_isprating = objects.data.client.isprating;
        var Client_rating = objects.data.client.rating;
        var Client_ispdlavg = objects.data.client.ispdlavg;
        var Client_ispulavg = objects.data.client.ispulavg;
        var Server_host = objects.data.server.host;
        var Server_lat = objects.data.server.lat;
        var Server_lon = objects.data.server.lon;
        var Server_location = objects.data.server.location;
        var Server_country = objects.data.server.country;
        var Server_cc = objects.data.server.cc;
        var Server_sponsor = objects.data.server.sponsor;
        var Server_distance = objects.data.server.distance;
        var Server_distanceMi = objects.data.server.distanceMi;
        var Server_ping = objects.data.server.ping;
        var Server_id = objects.data.server.id;
        setState(instanz + pfad + "json", jsonStr);
    
        setState(instanz + pfad + "ping", parseFloat(ping));
        //setState(instanz + pfad + "download", parseFloat(download));
        //setState(instanz + pfad + "upload", parseFloat(upload));
    
        setState(instanz + pfad + "data.speeds.download", parseFloat(Speed_Download));
        setState(instanz + pfad + "data.speeds.upload", parseFloat(Speed_Upload));
        setState(instanz + pfad + "data.speeds.orginalDownload", parseFloat(Speed_OriginalDownload));
        setState(instanz + pfad + "data.speeds.orginalUpload", parseFloat(Speed_OriginalUpload));
        setState(instanz + pfad + "data.client.ip", Client_IP);
        setState(instanz + pfad + "data.client.lat", parseFloat(Client_lat));
        setState(instanz + pfad + "data.client.lon", parseFloat(Client_lon));
        setState(instanz + pfad + "data.client.isp", Client_isp);
        setState(instanz + pfad + "data.client.isprating", parseFloat(Client_isprating));
        setState(instanz + pfad + "data.client.rating", parseFloat(Client_rating));
        setState(instanz + pfad + "data.client.ispdlavg", parseFloat(Client_ispdlavg));
        setState(instanz + pfad + "data.client.ispulavg", parseFloat(Client_ispulavg));
        setState(instanz + pfad + "data.server.host", Server_host);
        setState(instanz + pfad + "data.server.lat", parseFloat(Server_lat));
        setState(instanz + pfad + "data.server.lon", parseFloat(Server_lon));
        setState(instanz + pfad + "data.server.location", Server_location);
        setState(instanz + pfad + "data.server.country", Server_country);
        setState(instanz + pfad + "data.server.cc", Server_cc);
        setState(instanz + pfad + "data.server.sponsor", Server_sponsor);
        setState(instanz + pfad + "data.server.distance", parseFloat(Server_distance));
        setState(instanz + pfad + "data.server.distanceMi", parseFloat(Server_distanceMi));
        setState(instanz + pfad + "data.server.ping", parseFloat(Server_ping));
        setState(instanz + pfad + "data.server.id", parseFloat(Server_id));
        setState(instanz + pfad + 'forceRefresh', false);
        log('Speedtest Daten aktualisiert');
    }
    
    // regelmässige Wiederholungen
    schedule(cronStr, SpeedTest);
    
    // einmaliger Start bei Skriptstart
    createStates();
    
    setTimeout(SpeedTest, 1500);
    
    // Start beim Setzen auf true
    on(instanz + pfad + 'forceRefresh', function(obj) {
        if (!obj.state.ack && obj.state.val) SpeedTest();
    });
    

    Gruß
    Pix

    sigi234S Online
    sigi234S Online
    sigi234
    Forum Testing Most Active
    schrieb am zuletzt editiert von
    #65

    @pix sagte in Script für einen SpeedTest über speedtest.net:

    Hallo,

    es nervt mittlerweile, dass man die alten Skripte nicht mehr einfach verwenden/kopieren kann.
    Das neue Forum hat mich bisher mehr Zeit gekostet, als es gespart hat.

    Link Text

    Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.
    Immer Daten sichern!

    1 Antwort Letzte Antwort
    2
    • P pix

      Hallo,

      es nervt mittlerweile, dass man die alten Skripte nicht mehr einfach verwenden/kopieren kann.
      Das neue Forum hat mich bisher mehr Zeit gekostet, als es gespart hat.

      @Kueppert Du kannst natürlich nix dafür. Hier der Code vom genannten Post nochmal zusammenkopiert, falsche Zeichen entfernt und durch den Beautifier gejagt:

      /* Speed-Test
      SpeedTest mit Ausgabe von Down- / Uploadgeschwindigkeit und Ping
      http://forum.iobroker.net/viewtopic.php?f=21&t=4170
      Erstellt 10.11.2016 by Cybertron
      angepasst 14.03.2017 by Pix
      20.03.2017 Unit ms für Datenpunkt ping (danke 0018)
      Installation:
      npm install --global speed-test
      Aufruf:
      speed-test --json --verbose
      Beispiel-Ausgabe:
      {"ping":118,"download":2.2,"upload":2.2,"data":{"speeds":{"download":2.179,"upload":2.209,"originalDownload":239941,"originalUpload":242389},
      "client":{"ip":"xxx.xxx.xxx.xxx","lat":51.2993,"lon":9.491,"isp":"Deutsche Telekom","isprating":3,"rating":0,"ispdlavg":13.86,"ispulavg":3.108},
      "server":{"host":"speedtest.hillcom.de","lat":50.7511,"lon":9.2711,"location":"Alsfeld","country":"Germany","cc":"DE","sponsor":"HillCom Solutions",
      "distance":62.87,"distanceMi":39.06,"ping":117.8,"id":"6599"}}}
      */
      var logging = true;
      var instanz = 'javascript.' + instance + '.';
      var pfad = 'Speed-Test.';
      var cronStr = "29,59 * * * *";
      
      function createStates() {
          // Allgemein
          createState(pfad + 'json', {
              name: 'JSON',
              desc: 'JSON Ausgabe',
              type: 'string',
              role: 'json'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'json erstellt');
          });
          createState(pfad + 'ping', {
              name: 'Ping',
              desc: 'Ping',
              type: 'number',
              unit: 'ms',
              role: 'value'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'ping erstellt');
          });
      
          createState(pfad + 'forceRefresh', {
              name: 'aktualisieren',
              desc: 'Werte neu einlesen',
              type: 'boolean',
              def: false,
              role: 'indicator'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'forceRefresh erstellt');
          });
      
          // Speed
          createState(pfad + 'data.speeds.download', {
              name: 'Download',
              desc: 'Downloadgeschwindigkeit (Mbit/s)',
              type: 'number',
              unit: 'Mbit/s',
              role: 'value'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'data.speeds.download erstellt');
          });
          createState(pfad + 'data.speeds.upload', {
              name: 'Upload',
              desc: 'Uploadgeschwindigkeit (Mbit/s)',
              type: 'number',
              unit: 'Mbit/s',
              role: 'value'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'data.speeds.upload erstellt');
          });
          createState(pfad + 'data.speeds.orginalDownload', {
              name: 'OrginalDownload',
              desc: 'Downloadgeschwindigkeit (bit/s)',
              type: 'number',
              unit: 'bit/s',
              role: 'value'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'data.speeds.original Download erstellt');
          });
          createState(pfad + 'data.speeds.orginalUpload', {
              name: 'OrginalUpload',
              desc: 'Uploadgeschwindigkeit (bit/s)',
              type: 'number',
              unit: 'bit/s',
              role: 'value'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'data.speeds.originalUpload erstellt');
          });
          // Client
          createState(pfad + 'data.client.ip', {
              name: 'IP',
              desc: 'Öffentliche IP-Adresse',
              type: 'string',
              role: 'text'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'data.client.ip erstellt');
          });
          createState(pfad + 'data.client.lat', {
              name: 'Latitude',
              desc: 'Latidude',
              type: 'number', // ##########################
              unit: '°',
              role: 'value.gps.latitude'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'data.client.lat erstellt');
          });
          createState(pfad + 'data.client.lon', {
              name: 'Longitude',
              desc: 'Longitude',
              type: 'number', // ##########################
              unit: '°',
              role: 'value.gps.longitude'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'data.client.lomg erstellt');
          });
          createState(pfad + 'data.client.isp', {
              name: 'ISP',
              desc: 'Internet-Service-provider',
              type: 'string',
              role: 'text'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'data.client.isp erstellt');
          });
      
          createState(pfad + 'data.client.isprating', {
              name: 'ISP-Rating',
              desc: 'ISP-Rating',
              type: 'number',
              role: 'value'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'data.client.isprating erstellt');
          });
      
          createState(pfad + 'data.client.rating', {
              name: 'Rating',
              desc: 'Rating',
              type: 'number',
              role: 'value'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'data.client.rating erstellt');
          });
      
          createState(pfad + 'data.client.ispdlavg', {
              name: 'ISP-DL-AVG',
              desc: 'ISPDLAVG',
              type: 'number',
              unit: 'Mbit/s',
              role: 'value'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'data.client.ispdlavg erstellt');
          });
      
          createState(pfad + 'data.client.ispulavg', {
              name: 'ISP-UL-AVG',
              desc: 'ISPULAVG',
              type: 'number',
              unit: 'Mbit/s',
              role: 'value'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'data.client.ispulavg erstellt');
          });
      
          // Server
          createState(pfad + 'data.server.host', {
              name: 'Host',
              desc: 'Hostname des Servers',
              type: 'string',
              role: 'text'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'data.server.host erstellt');
          });
      
      
          createState(pfad + 'data.server.lat', {
              name: 'Server-Latitude',
              desc: 'Latitude des Serverstandortes',
              type: 'number', // ##########################
              unit: '°',
              role: 'value.gps.latitude'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'data.server.lat erstellt');
          });
      
          createState(pfad + 'data.server.lon', {
              name: 'Server-Longitude',
              desc: 'Longitude des Serverstandortes',
              type: 'number', // ##########################
              unit: '°',
              role: 'value.gps.longitude'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'data.server.lon erstellt');
          });
      
          createState(pfad + 'data.server.location', {
              name: 'Server-Location',
              desc: 'Server-Standort',
              type: 'string',
              role: 'text.city'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'data.server.location erstellt');
          });
      
          createState(pfad + 'data.server.country', {
              name: 'Server-Country',
              desc: 'Land',
              type: 'string',
              role: 'text.country'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'data.server.country erstellt');
          });
      
          createState(pfad + 'data.server.cc', {
              name: 'Server-CC',
              desc: 'Länderkürzel',
              type: 'string',
              role: 'text'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'data.server.cc erstellt');
          });
      
          createState(pfad + 'data.server.sponsor', {
              name: 'Server-Sponsor',
              desc: 'Sponsor des Servers',
              type: 'string',
              role: 'text'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'data.server.sponsor erstellt');
          });
      
          createState(pfad + 'data.server.distance', {
              name: 'DistanzToServer',
              desc: 'Distanz zum Server in km',
              type: 'number',
              unit: 'km',
              role: 'value'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'data.server.distance erstellt');
          });
      
          createState(pfad + 'data.server.distanceMi', {
              name: 'DistanzToServerMeilen',
              desc: 'Distanz des Servers im Meilen',
              type: 'number',
              unit: 'Meilen',
              role: 'value'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'data.server.distanceMi erstellt');
          });
      
          createState(pfad + 'data.server.ping', {
              name: 'Server-Ping',
              desc: 'Ping zum Server',
              type: 'number',
              unit: 'ms',
              role: 'value'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'data.server.ping erstellt');
          });
      
          createState(pfad + 'data.server.id', {
              name: 'Server-ID',
              desc: 'Server ID',
              type: 'number',
              role: 'value'
          }, function() {
              if (logging) log('Objekt ' + instanz + pfad + 'data.server.id erstellt');
          });
      
      }
      
      function SpeedTest() {
          exec("speed-test --json --verbose", function(err, stdout, stderr) {
              if (err) {
                  log(stderr, 'error');
                  log('Speedtest Daten konnten nicht abgefragt werden', 'error');
                  return;
              }
              writeDP(stdout);
          });
      }
      
      function writeDP(jsonstring) {
          var objects = JSON.parse(jsonstring);
      
          var jsonStr = jsonstring;
          //log (jsonStr);
      
          var ping = objects.ping;
          var download = objects.download;
          var upload = objects.upload;
          //log ('Ping =' + ping);
          //log ('Download = ' + download);
          //log ('Upload = ' + upload);
          var Speed_Download = objects.data.speeds.download;
          var Speed_Upload = objects.data.speeds.upload;
          var Speed_OriginalDownload = objects.data.speeds.originalDownload;
          var Speed_OriginalUpload = objects.data.speeds.originalUpload;
          //log ('Speed_Download = ' + Speed_Download);
          //log ('Speed_Upload = ' + Speed_Upload);
          //log ('OriginalDownload = ' + Speed_OriginalDownload);
          //log ('OriginalUpload = ' + Speed_OriginalUpload);
          var Client_IP = objects.data.client.ip;
          var Client_lat = objects.data.client.lat;
          var Client_lon = objects.data.client.lon;
          var Client_isp = objects.data.client.isp;
          var Client_isprating = objects.data.client.isprating;
          var Client_rating = objects.data.client.rating;
          var Client_ispdlavg = objects.data.client.ispdlavg;
          var Client_ispulavg = objects.data.client.ispulavg;
          var Server_host = objects.data.server.host;
          var Server_lat = objects.data.server.lat;
          var Server_lon = objects.data.server.lon;
          var Server_location = objects.data.server.location;
          var Server_country = objects.data.server.country;
          var Server_cc = objects.data.server.cc;
          var Server_sponsor = objects.data.server.sponsor;
          var Server_distance = objects.data.server.distance;
          var Server_distanceMi = objects.data.server.distanceMi;
          var Server_ping = objects.data.server.ping;
          var Server_id = objects.data.server.id;
          setState(instanz + pfad + "json", jsonStr);
      
          setState(instanz + pfad + "ping", parseFloat(ping));
          //setState(instanz + pfad + "download", parseFloat(download));
          //setState(instanz + pfad + "upload", parseFloat(upload));
      
          setState(instanz + pfad + "data.speeds.download", parseFloat(Speed_Download));
          setState(instanz + pfad + "data.speeds.upload", parseFloat(Speed_Upload));
          setState(instanz + pfad + "data.speeds.orginalDownload", parseFloat(Speed_OriginalDownload));
          setState(instanz + pfad + "data.speeds.orginalUpload", parseFloat(Speed_OriginalUpload));
          setState(instanz + pfad + "data.client.ip", Client_IP);
          setState(instanz + pfad + "data.client.lat", parseFloat(Client_lat));
          setState(instanz + pfad + "data.client.lon", parseFloat(Client_lon));
          setState(instanz + pfad + "data.client.isp", Client_isp);
          setState(instanz + pfad + "data.client.isprating", parseFloat(Client_isprating));
          setState(instanz + pfad + "data.client.rating", parseFloat(Client_rating));
          setState(instanz + pfad + "data.client.ispdlavg", parseFloat(Client_ispdlavg));
          setState(instanz + pfad + "data.client.ispulavg", parseFloat(Client_ispulavg));
          setState(instanz + pfad + "data.server.host", Server_host);
          setState(instanz + pfad + "data.server.lat", parseFloat(Server_lat));
          setState(instanz + pfad + "data.server.lon", parseFloat(Server_lon));
          setState(instanz + pfad + "data.server.location", Server_location);
          setState(instanz + pfad + "data.server.country", Server_country);
          setState(instanz + pfad + "data.server.cc", Server_cc);
          setState(instanz + pfad + "data.server.sponsor", Server_sponsor);
          setState(instanz + pfad + "data.server.distance", parseFloat(Server_distance));
          setState(instanz + pfad + "data.server.distanceMi", parseFloat(Server_distanceMi));
          setState(instanz + pfad + "data.server.ping", parseFloat(Server_ping));
          setState(instanz + pfad + "data.server.id", parseFloat(Server_id));
          setState(instanz + pfad + 'forceRefresh', false);
          log('Speedtest Daten aktualisiert');
      }
      
      // regelmässige Wiederholungen
      schedule(cronStr, SpeedTest);
      
      // einmaliger Start bei Skriptstart
      createStates();
      
      setTimeout(SpeedTest, 1500);
      
      // Start beim Setzen auf true
      on(instanz + pfad + 'forceRefresh', function(obj) {
          if (!obj.state.ack && obj.state.val) SpeedTest();
      });
      

      Gruß
      Pix

      K Offline
      K Offline
      Kueppert
      schrieb am zuletzt editiert von
      #66

      @pix super, danke dir, läuft wieder

      UDM Pro, Intel NUC - ioBroker in Proxmox-VM, PiHole+Grafana&Influx+TasmoAdmin in LXCs, Raspberry Pi3 (als CCU), Zigbee-Stick Sonoff, Synology DS918+

      1 Antwort Letzte Antwort
      0
      • juergen2908J Offline
        juergen2908J Offline
        juergen2908
        schrieb am zuletzt editiert von
        #67

        Hallo,

        habe speedtest installiert bekomme auf der cmd das Ergebniss angezeigt aber beim skript kommt folgender fehler:

        7d21693f-bf9a-456f-b81b-0b26c9288af1-image.png

        iobroker läuft auf windwos 10

        bitte um Hilfe!

        LG

        Jürgen

        D 1 Antwort Letzte Antwort
        0
        • juergen2908J juergen2908

          Hallo,

          habe speedtest installiert bekomme auf der cmd das Ergebniss angezeigt aber beim skript kommt folgender fehler:

          7d21693f-bf9a-456f-b81b-0b26c9288af1-image.png

          iobroker läuft auf windwos 10

          bitte um Hilfe!

          LG

          Jürgen

          D Offline
          D Offline
          dos1973
          schrieb am zuletzt editiert von
          #68

          @juergen2908
          Hast du

          Installation:
          npm install --global speed-test
          

          durchgeführt?

          1 Antwort Letzte Antwort
          0
          • juergen2908J Offline
            juergen2908J Offline
            juergen2908
            schrieb am zuletzt editiert von juergen2908
            #69

            Hallo dos1973,

            ja natürlich, wenn ich dem befehl im cmd ausführe bekomme ich ein Ausgabe, nur im Skript findet er den Pfad nicht:
            in der Ausgabe steht schön alles drinnen:
            b417b368-cddf-411f-95ac-917501b2fe1d-image.png

            1 Antwort Letzte Antwort
            0
            • T Offline
              T Offline
              tempestas
              schrieb am zuletzt editiert von
              #70

              ich bekomme noch immer folgendes:

              javascript.0 script.js.common.System.Internet: /usr/lib/node_modules/speed-test/cli.js:93 server.host = new URL(server.url).host; ^ TypeError: URL is not a constructor at map (/usr/lib/node_modules/speed-test/cli.js:93:16) at EventEmitter.st.once.server (/usr/lib/node_modules/speed-test/cli.js:108:12) at EventEmitter.g (events.js:292:16) at emitOne (events.js:96:13) at EventEmitter.emit (events.js:188:7) at startDownload (/usr/lib/node_modules/speed-test/node_modules/speedtest-net/index.js:683:10) at /usr/lib/node_modules/speed-test/node_modules/speedtest-net/index.js:660:7 at /usr/lib/node_modules/speed-test/node_modules/speedtest-net/index.js:364:11 at /usr/lib/node_modules/speed-test/node_modules/speedtest-net/index.js:97:16 at /usr/lib/node_modules/speed-test/node_modules/speedtest-net/index.js:329:16
              21:20:15.464	[error]	javascript.0 script.js.common.System.Internet: Speedtest Daten konnten nicht abgefragt werden
              

              Was kann / muss ich tun?

              <size="85">ioBroker | 21 Adapter | Ubuntu Server | intel NUC | Homematic CCU2 | Hue | Osram Lightify| Sonos | 2x Instar Cam | Samsung Tab A 2016 im Holzrahmen| 3x Echo dot | 1x Echo | Neato Botvac D5</size>

              1 Antwort Letzte Antwort
              0
              • Elektroniker86E Offline
                Elektroniker86E Offline
                Elektroniker86
                schrieb am zuletzt editiert von
                #71

                Hallo, ich häng mich hier mal dran.

                Hab ebenfalls das selbe Problem, ich habe das hier installiert:

                npm install --global speed-test

                Meine npm Version ist die 6.4.1 auf einem Tinkerboard S. Übrigens, hat er mir vorgeschlagen ein Update auf npm 6.9.0 zu machen, das habe ich mich allerdings nicht getraut.

                Wenn ich den den Befehl in putty ausführe (speed-test --json --verbose) sieht es aber gut aus. An was könnte das liegen?

                Hier noch ein Screenshot

                Unbenannt.png

                Unbenannt2.png

                T 1 Antwort Letzte Antwort
                0
                • Elektroniker86E Elektroniker86

                  Hallo, ich häng mich hier mal dran.

                  Hab ebenfalls das selbe Problem, ich habe das hier installiert:

                  npm install --global speed-test

                  Meine npm Version ist die 6.4.1 auf einem Tinkerboard S. Übrigens, hat er mir vorgeschlagen ein Update auf npm 6.9.0 zu machen, das habe ich mich allerdings nicht getraut.

                  Wenn ich den den Befehl in putty ausführe (speed-test --json --verbose) sieht es aber gut aus. An was könnte das liegen?

                  Hier noch ein Screenshot

                  Unbenannt.png

                  Unbenannt2.png

                  T Offline
                  T Offline
                  tempestas
                  schrieb am zuletzt editiert von
                  #72

                  @Elektroniker86 said in Script für einen SpeedTest über speedtest.net:

                  Hallo, ich häng mich hier mal dran.

                  Hab ebenfalls das selbe Problem, ich habe das hier installiert:

                  npm install --global speed-test

                  Meine npm Version ist die 6.4.1 auf einem Tinkerboard S. Übrigens, hat er mir vorgeschlagen ein Update auf npm 6.9.0 zu machen, das habe ich mich allerdings nicht getraut.

                  Wenn ich den den Befehl in putty ausführe (speed-test --json --verbose) sieht es aber gut aus. An was könnte das liegen?

                  Hier noch ein Screenshot

                  Unbenannt.png

                  Unbenannt2.png

                  Du musst exec aktivieren in deinen JS Adapter Einstellungen.

                  <size="85">ioBroker | 21 Adapter | Ubuntu Server | intel NUC | Homematic CCU2 | Hue | Osram Lightify| Sonos | 2x Instar Cam | Samsung Tab A 2016 im Holzrahmen| 3x Echo dot | 1x Echo | Neato Botvac D5</size>

                  1 Antwort Letzte Antwort
                  1
                  • Elektroniker86E Offline
                    Elektroniker86E Offline
                    Elektroniker86
                    schrieb am zuletzt editiert von
                    #73

                    Super, vielen Dank!
                    Das war es, jetzt funktioniert es einwandfrei !:+1:

                    1 Antwort Letzte Antwort
                    0
                    • O Online
                      O Online
                      Oli
                      schrieb am zuletzt editiert von
                      #74

                      Hallo zusammen,

                      ich habe ioBroker als Docker auf meinem Qnap installiert, kann mir jemand sagen, wie ich da "npm install --global speed-test" installieren kann?

                      Gruß
                      Oliver

                      D 1 Antwort Letzte Antwort
                      0
                      • O Oli

                        Hallo zusammen,

                        ich habe ioBroker als Docker auf meinem Qnap installiert, kann mir jemand sagen, wie ich da "npm install --global speed-test" installieren kann?

                        D Offline
                        D Offline
                        dos1973
                        schrieb am zuletzt editiert von
                        #75

                        @Oli
                        Ich meine über die Docker Oberfläche bei der Konfig des Images hast du ein Terminal zur Verfügung...

                        O 1 Antwort Letzte Antwort
                        0
                        • D dos1973

                          @Oli
                          Ich meine über die Docker Oberfläche bei der Konfig des Images hast du ein Terminal zur Verfügung...

                          O Online
                          O Online
                          Oli
                          schrieb am zuletzt editiert von
                          #76

                          @dos1973

                          ja habe ich

                          Gruß
                          Oliver

                          1 Antwort Letzte Antwort
                          0
                          • rockthenetR Offline
                            rockthenetR Offline
                            rockthenet
                            schrieb am zuletzt editiert von
                            #77
                            Dieser Beitrag wurde gelöscht!
                            1 Antwort Letzte Antwort
                            0
                            • rockthenetR Offline
                              rockthenetR Offline
                              rockthenet
                              schrieb am zuletzt editiert von
                              #78
                              Dieser Beitrag wurde gelöscht!
                              1 Antwort Letzte Antwort
                              0
                              • A Offline
                                A Offline
                                aleks-83
                                schrieb am zuletzt editiert von
                                #79

                                Hi,

                                ich bin von meiner Debian VM auf natives Win10 umgestiegen.
                                Seitdem findet er "speed-test" nicht mehr.

                                javascript.0	2019-09-25 12:00:01.242	error	script.js.FritzBox.speedtest: Der Befehl "speed-test" ist entweder falsch geschrieben oder konnte nicht gefunden werden
                                

                                speed-test ist installiert und im javascript Adapter eingetragen.
                                Ich habe den Javascript Adapter und auch komplett ioBroker neu gestartet.
                                Trotzdem bleibt die Meldung.

                                = Dell Optiplex Micro - 10GB RAM - 200GB SSD - Debian VM =
                                = Node.js v20.18.3 = NPM 10.2.3 = JS Controller 7.0.6 =

                                Ubiquiti UAP-AC-LR - UAP-AC-Lite - Synology DS716+II - Fritz!Box 7490
                                Glasfaser 400

                                A 1 Antwort Letzte Antwort
                                0
                                • C Offline
                                  C Offline
                                  Coffeelover
                                  schrieb am zuletzt editiert von
                                  #80

                                  Hallo zusammen,
                                  Achtung Anfängerfrage: wie bekomme ich eine graphische Darstellung der Werte über den Zeitverlauf in vis dargestellt?
                                  VG

                                  sigi234S NegaleinN 2 Antworten Letzte Antwort
                                  0
                                  • C Coffeelover

                                    Hallo zusammen,
                                    Achtung Anfängerfrage: wie bekomme ich eine graphische Darstellung der Werte über den Zeitverlauf in vis dargestellt?
                                    VG

                                    sigi234S Online
                                    sigi234S Online
                                    sigi234
                                    Forum Testing Most Active
                                    schrieb am zuletzt editiert von
                                    #81

                                    @Coffeelover sagte in Script für einen SpeedTest über speedtest.net:

                                    Hallo zusammen,
                                    Achtung Anfängerfrage: wie bekomme ich eine graphische Darstellung der Werte über den Zeitverlauf in vis dargestellt?
                                    VG

                                    Flot und History Adapter

                                    Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.
                                    Immer Daten sichern!

                                    1 Antwort Letzte Antwort
                                    0
                                    • C Coffeelover

                                      Hallo zusammen,
                                      Achtung Anfängerfrage: wie bekomme ich eine graphische Darstellung der Werte über den Zeitverlauf in vis dargestellt?
                                      VG

                                      NegaleinN Offline
                                      NegaleinN Offline
                                      Negalein
                                      Global Moderator
                                      schrieb am zuletzt editiert von Negalein
                                      #82

                                      @Coffeelover sagte in Script für einen SpeedTest über speedtest.net:

                                      Achtung Anfängerfrage: wie bekomme ich eine graphische Darstellung der Werte über den Zeitverlauf in vis dargestellt?

                                      Hier als Beispiel der Flot von mir!

                                      IP in deine ändern und index.html in edit.html ändern.
                                      Dann wird direkt im Flot-Edit geöffnet.

                                      Und natürlich die passenden DP in History aufzeichnen lassen.

                                      http://10.0.1.200:8082/flot/index.html?l%5B0%5D%5Bid%5D=javascript.0.Speed-Test.data.speeds.download&l%5B0%5D%5Boffset%5D=0&l%5B0%5D%5Baggregate%5D=average&l%5B0%5D%5Bcolor%5D=%23ff3333&l%5B0%5D%5Bmin%5D=8&l%5B0%5D%5Bmax%5D=50&l%5B0%5D%5Bthickness%5D=2&l%5B0%5D%5Bshadowsize%5D=2&l%5B0%5D%5Bunit%5D=m%2Fbit&l%5B0%5D%5Bname%5D=Download&l%5B0%5D%5Byaxe%5D=rightColor&l%5B0%5D%5Bxaxe%5D=bottom&l%5B0%5D%5Bpoints%5D=false&l%5B0%5D%5Bv%5D=landroid-s.0.mower.status&l%5B0%5D%5Bvl%5D=landroid-s.0.mower.status&l%5B0%5D%5BchartType%5D=spline&l%5B0%5D%5BafterComma%5D=1&l%5B0%5D%5Bdashes%5D=false&l%5B0%5D%5BdashLength%5D=10&l%5B0%5D%5BspaceLength%5D=10&l%5B0%5D%5Bsmoothing%5D=1&l%5B0%5D%5BignoreNull%5D=false&l%5B0%5D%5Byticks%5D=20&l%5B0%5D%5Binstance%5D=history.0&l%5B0%5D%5Bfill%5D=0&l%5B0%5D%5BcommonYAxis%5D=1&l%5B1%5D%5Bid%5D=javascript.0.Speed-Test.ping&l%5B1%5D%5Boffset%5D=0&l%5B1%5D%5Baggregate%5D=average&l%5B1%5D%5Bcolor%5D=%2333ff33&l%5B1%5D%5Bthickness%5D=1&l%5B1%5D%5Bshadowsize%5D=1&l%5B1%5D%5Bunit%5D=ms&l%5B1%5D%5Byaxe%5D=rightColor&l%5B1%5D%5Bname%5D=Ping&l%5B1%5D%5Bxaxe%5D=off&l%5B1%5D%5Bmin%5D=0.1&l%5B1%5D%5Bmax%5D=120&l%5B1%5D%5BafterComma%5D=0&l%5B1%5D%5Bdashes%5D=false&l%5B1%5D%5BdashLength%5D=10&l%5B1%5D%5BspaceLength%5D=10&l%5B1%5D%5BchartType%5D=spline&l%5B1%5D%5Binstance%5D=history.0&l%5B1%5D%5Bfill%5D=0&l%5B1%5D%5Bpoints%5D=false&l%5B1%5D%5BcommonYAxis%5D=1&l%5B2%5D%5Bid%5D=javascript.0.Speed-Test.data.speeds.upload&l%5B2%5D%5Boffset%5D=0&l%5B2%5D%5Baggregate%5D=average&l%5B2%5D%5Bcolor%5D=%2344ffFF&l%5B2%5D%5Bmin%5D=0.1&l%5B2%5D%5Bmax%5D=20&l%5B2%5D%5Bthickness%5D=2&l%5B2%5D%5Bshadowsize%5D=2&l%5B2%5D%5Bunit%5D=m%2FBit&l%5B2%5D%5Bname%5D=Upload&l%5B2%5D%5Byaxe%5D=rightColor&l%5B2%5D%5Bxaxe%5D=off&l%5B2%5D%5BignoreNull%5D=false&l%5B2%5D%5BafterComma%5D=1&l%5B2%5D%5Bdashes%5D=false&l%5B2%5D%5BdashLength%5D=10&l%5B2%5D%5BspaceLength%5D=10&l%5B2%5D%5Byticks%5D=3&l%5B2%5D%5BchartType%5D=spline&l%5B2%5D%5Binstance%5D=history.0&l%5B2%5D%5Bfill%5D=0&l%5B2%5D%5Bpoints%5D=false&l%5B2%5D%5BcommonYAxis%5D=1&timeType=relative&relativeEnd=now&range=2880&live=900&aggregateType=step&aggregateSpan=300&window_bg=%23202020&bg=%23202020&legend=nw&hoverDetail=true&useComma=false&zoom=true&noedit=true&animation=0&noBorder=noborder&barLabels=topover&titleColor=%23000000&titleSize=15&legColumns=5&timeFormat=%25H%3A%25M&legBgOpacity=0.7&border_color=%23202020&start=2019-05-29&start_time=13%3A38&barWidth=0.1&barFontSize=12px&barFontColor=%23000000&legBg=%23ffffff&end=2019-01-27&end_time=23%3A59&x_labels_color=%23ffffff&y_labels_color=%23ffffff&title=Stromverbrauch&border_width=1&barColor=dsf
                                      

                                      ° Node.js: 20.17.0 NPM: 10.8.2
                                      ° Proxmox, Ubuntu 22.04.3 LTS
                                      ° Fixer ---> iob fix

                                      1 Antwort Letzte Antwort
                                      0
                                      • C Offline
                                        C Offline
                                        Coffeelover
                                        schrieb am zuletzt editiert von
                                        #83

                                        Danke euch beiden. Habe ich hinbekommen und an meine VIS angepasst.

                                        Jetzt frage ich mich nur, was mir die Werte sagen:
                                        Download lt. Adapter: 1.272 Mbit/s, ORIGDONWLOAD 140127 bit/s
                                        Ein gleichzeitig durchgeführter DSL Speedcheck zeigt mir etwa 46.000 kBit/s?

                                        VG

                                        ? 1 Antwort Letzte Antwort
                                        0
                                        • C Offline
                                          C Offline
                                          Coffeelover
                                          schrieb am zuletzt editiert von
                                          #84

                                          Hallo nochmal,

                                          ich möchte nochmals nachfragen, da mir die ausgewerteten Daten nicht plausibel vorkommen: Habe ich etwas falsch gemacht oder nicht entsprechend konfiguriert?

                                          Ich nutze iobroker in einem Docker auf meinem NAS. Selbiger ist per Gigabit-Leitung mit dem Router verbunden. Der Router wiederum hängt via Kabel an der Vodafone Kabel Box.

                                          VG

                                          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

                                          459

                                          Online

                                          32.4k

                                          Benutzer

                                          81.4k

                                          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