Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

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

NEWS

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

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.2k

Script für einen SpeedTest über speedtest.net

Scheduled Pinned Locked Moved Skripten / Logik
javascript
177 Posts 57 Posters 45.6k Views 39 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • 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
    wrote on last edited by
    #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 Reply Last reply
    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
      wrote on last edited by
      #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 Reply Last reply
      0
      • juergen2908J Offline
        juergen2908J Offline
        juergen2908
        wrote on last edited by
        #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 Reply Last reply
        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
          wrote on last edited by
          #68

          @juergen2908
          Hast du

          Installation:
          npm install --global speed-test
          

          durchgeführt?

          1 Reply Last reply
          0
          • juergen2908J Offline
            juergen2908J Offline
            juergen2908
            wrote on last edited by 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 Reply Last reply
            0
            • T Offline
              T Offline
              tempestas
              wrote on last edited by
              #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 Reply Last reply
              0
              • Elektroniker86E Offline
                Elektroniker86E Offline
                Elektroniker86
                wrote on last edited by
                #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 Reply Last reply
                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
                  wrote on last edited by
                  #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 Reply Last reply
                  1
                  • Elektroniker86E Offline
                    Elektroniker86E Offline
                    Elektroniker86
                    wrote on last edited by
                    #73

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

                    1 Reply Last reply
                    0
                    • O Offline
                      O Offline
                      Oli
                      wrote on last edited by
                      #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 Reply Last reply
                      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
                        wrote on last edited by
                        #75

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

                        O 1 Reply Last reply
                        0
                        • D dos1973

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

                          O Offline
                          O Offline
                          Oli
                          wrote on last edited by
                          #76

                          @dos1973

                          ja habe ich

                          Gruß
                          Oliver

                          1 Reply Last reply
                          0
                          • rockthenetR Offline
                            rockthenetR Offline
                            rockthenet
                            wrote on last edited by
                            #77
                            This post is deleted!
                            1 Reply Last reply
                            0
                            • rockthenetR Offline
                              rockthenetR Offline
                              rockthenet
                              wrote on last edited by
                              #78
                              This post is deleted!
                              1 Reply Last reply
                              0
                              • A Offline
                                A Offline
                                aleks-83
                                wrote on last edited by
                                #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.19.6 = NPM 10.8.2 = JS Controller 7.0.7 =

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

                                A 1 Reply Last reply
                                0
                                • C Offline
                                  C Offline
                                  Coffeelover
                                  wrote on last edited by
                                  #80

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

                                  sigi234S NegaleinN 2 Replies Last reply
                                  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
                                    wrote on last edited by
                                    #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 Reply Last reply
                                    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
                                      wrote on last edited by 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 & System Update ---> sudo apt update, iob stop, sudo apt full-upgrade
                                      ° Node.js Fixer ---> iob nodejs-update
                                      ° Fixer ---> iob fix

                                      1 Reply Last reply
                                      0
                                      • C Offline
                                        C Offline
                                        Coffeelover
                                        wrote on last edited by
                                        #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 Reply Last reply
                                        0
                                        • C Offline
                                          C Offline
                                          Coffeelover
                                          wrote on last edited by
                                          #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 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          515

                                          Online

                                          32.6k

                                          Users

                                          82.2k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe