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

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

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

NEWS

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

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

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

Script für einen SpeedTest über speedtest.net

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
javascript
177 Beiträge 57 Kommentatoren 42.8k Aufrufe 39 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • P pix

    Hallo 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
    schrieb am zuletzt editiert von
    #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 Antwort Letzte Antwort
    0
    • P Offline
      P Offline
      pix
      schrieb am zuletzt editiert von
      #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 Antworten Letzte Antwort
      2
      • P pix

        Hallo,

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

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

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

        Gruß
        Pix

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

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

        Hallo,

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

        Link Text

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

        1 Antwort Letzte Antwort
        2
        • P pix

          Hallo,

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

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

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

          Gruß
          Pix

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

          @pix super, danke dir, läuft wieder

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

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

            Hallo,

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

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

            iobroker läuft auf windwos 10

            bitte um Hilfe!

            LG

            Jürgen

            D 1 Antwort Letzte Antwort
            0
            • juergen2908J juergen2908

              Hallo,

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

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

              iobroker läuft auf windwos 10

              bitte um Hilfe!

              LG

              Jürgen

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

              @juergen2908
              Hast du

              Installation:
              npm install --global speed-test
              

              durchgeführt?

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

                Hallo dos1973,

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

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

                  ich bekomme noch immer folgendes:

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

                  Was kann / muss ich tun?

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

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

                    Hallo, ich häng mich hier mal dran.

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

                    npm install --global speed-test

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

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

                    Hier noch ein Screenshot

                    Unbenannt.png

                    Unbenannt2.png

                    T 1 Antwort Letzte Antwort
                    0
                    • Elektroniker86E Elektroniker86

                      Hallo, ich häng mich hier mal dran.

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

                      npm install --global speed-test

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

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

                      Hier noch ein Screenshot

                      Unbenannt.png

                      Unbenannt2.png

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

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

                      Hallo, ich häng mich hier mal dran.

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

                      npm install --global speed-test

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

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

                      Hier noch ein Screenshot

                      Unbenannt.png

                      Unbenannt2.png

                      Du musst exec aktivieren in deinen JS Adapter Einstellungen.

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

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

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

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

                          Hallo zusammen,

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

                          Gruß
                          Oliver

                          D 1 Antwort Letzte Antwort
                          0
                          • O Oli

                            Hallo zusammen,

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

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

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

                            O 1 Antwort Letzte Antwort
                            0
                            • D dos1973

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

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

                              @dos1973

                              ja habe ich

                              Gruß
                              Oliver

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

                                    Hi,

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

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

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

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

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

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

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

                                      sigi234S NegaleinN 2 Antworten Letzte Antwort
                                      0
                                      • C Coffeelover

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

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

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

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

                                        Flot und History Adapter

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

                                        1 Antwort Letzte Antwort
                                        0
                                        • C Coffeelover

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

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

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

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

                                          Hier als Beispiel der Flot von mir!

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

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

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

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

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


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          629

                                          Online

                                          32.4k

                                          Benutzer

                                          81.4k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe