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

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    16
    1
    278

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

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

Script für einen SpeedTest über speedtest.net

Scheduled Pinned Locked Moved Skripten / Logik
javascript
177 Posts 57 Posters 46.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 Silvio,

    ich habe das Skript für mich angepasst und dabei einige Kleinigkeiten ausgebessert. Ausserdem sind jetzt Roles vergeben und ein Schalter zum Aktualisieren für VIS eingebaut.

    ! ````
    /* 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();
    });
    ! ````
    EDIT:

    Skript geändert am 14.03.2016 16:58 Uhr

    20.03.2017 Einheit ms für Datenpunkt Ping eingepflegt (danke http://forum.iobroker.net/viewtopic.php?f=21&t=4170#p59581)

    Danke für die Idee und Vorlage.

    Gruß

    Pix

    EDIT 27.05.2019: Hier ist die reparierte Variante des Skripts (Fehler nach Forumumstellung 2019) https://forum.iobroker.net/post/264927

    K Offline
    K Offline
    Kueppert
    wrote on last edited by
    #63

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

    /* 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","l

    Huhu PIX,
    das Skript ist im neuen Forum leider total kaputt gegangen. Das Skript von aleks-83 startet bei mir leider nicht. Wollte daher nochmal deines ausprobieren um sicher zu gehen, dass es nicht an meinem JS liegt...danke.

    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
    • P Offline
      P Offline
      pix
      wrote on last edited by
      #64

      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

      ioBroker auf Ubuntu in Proxmox (früher Mac mini (bis OS X 10.12.6 Sierra), VIS via iOS; angeschlossen: Homematic CCU2, Homepilot 1, ConBee II, einige Wemos, Sonos, Unifi CK+Protect, Homekit, Homebridge; KEIN blockly! Github-Profil

      sigi234S K 2 Replies 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

        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
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          249

                                          Online

                                          32.7k

                                          Users

                                          82.5k

                                          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