NEWS
Script für einen SpeedTest über speedtest.net
-
@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","lHuhu 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. -
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 -
@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. -
@pix super, danke dir, läuft wieder
-
Hallo,
habe speedtest installiert bekomme auf der cmd das Ergebniss angezeigt aber beim skript kommt folgender fehler:
iobroker läuft auf windwos 10
bitte um Hilfe!
LG
Jürgen
-
-
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:
-
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?
-
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
-
@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
Du musst exec aktivieren in deinen JS Adapter Einstellungen.
-
Super, vielen Dank!
Das war es, jetzt funktioniert es einwandfrei ! -
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?
-
@Oli
Ich meine über die Docker Oberfläche bei der Konfig des Images hast du ein Terminal zur Verfügung... -
ja habe ich
-
This post is deleted! -
This post is deleted! -
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. -
Hallo zusammen,
Achtung Anfängerfrage: wie bekomme ich eine graphische Darstellung der Werte über den Zeitverlauf in vis dargestellt?
VG -
@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?
VGFlot und History Adapter
-
@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