En estos días he tenido intermitencias en el servicio de internet.
Mi forma de comprobarlo es entrar en una consola y hacer ping a un host, como google.com, y ver si está ok o no.
$ ping google.com -t
El -t permite que el ping se haga indefinidamente, hasta que se presione CTR + C.
Sin embargo, quería una forma de mostrar los cambios de estado, a qué hora ocurrían y cuánto duraban.
Programé esta solución usando nodejs:
GitHub Gist: Internet test with ping in NodeJS
const ping = require('ping');
let host = '8.8.8.8';
if (process.argv[2]) {
host = process.argv[2];
} else {
console.log("Syntax: \nnode ping-test-ifchanges-host host");
}
console.log("Testing host: " + host);
let isAlivePrev = false;
let nowPrev = new Date();
function doPing() {
ping.sys.probe(host, isAlive => {
if (isAlive !== isAlivePrev) {
let now = new Date();
let diff = (now.getTime() - nowPrev.getTime())/1000;
let timestamp = now.toISOString() + ' after: ' + diff + ' s';
console.log("\n"
+ host + ': '
+ (isAlive ? ' OK' : ' KO')
+ ' ' + timestamp);
isAlivePrev = isAlive;
nowPrev = now;
} else {
process.stdout.write('.');
}
});
}
setInterval(doPing, 1000);
Para correrlo en consola:
$ node ping-test-ifchanges-host google.com
Idea
setInterval() establece un llamado, cada 1000 ms, a doPing(), que hace un ping al host que se haya indicado y revisa si hay un cambio de estado.
Si hay un cambio de estado, anota el tiempo y muestra las diferencias respecto al tiempo anterior.
Si no hay cambio de estado, imprime simplemente un punto.


No hay comentarios.:
Publicar un comentario