2
0
mirror of https://github.com/munin-monitoring/contrib.git synced 2018-11-08 00:59:34 +01:00

Background Process for Speed Test (no timeout)

This commit is contained in:
Tanguy Pruvot 2011-01-24 17:38:31 +01:00 committed by Steve Schnepp
parent 0d3d197fea
commit 3abf7831eb

View File

@ -3,36 +3,52 @@
global $argc, $argv; global $argc, $argv;
/************************************************************************** /**************************************************************************
Test de bande passante multi sites, test un site à la fois SpeedTest multi-sites, test one site at a time (in background)
v1.2 - tanguy.pruvot on gmail.com v1.4 - tanguy.pruvot on gmail.com (24 Jan 2011)
***************************************************************************/ ***************************************************************************/
$cache_file = '/var/lib/munin/speedtest.cache'; $cache_file = '/var/lib/munin/speedtest.cache';
$grenouille_csv = '/usr/local/pygrenouille/logs/download.csv'; $grenouille_csv = '/usr/local/pygrenouille/logs/download.csv';
$mire = array( $mire = array(
"free" => "http://test-debit.free.fr/16384.rnd", "free" => "http://test-debit.free.fr/16384.rnd",
"gaoland" => "http://mire.ipadsl.net/speedtest.php", //"bouygues" => "http://speedtest.lafibre.info/speedtest/random2000x2000.jpg?x=".date('U'),
"bouygues" => "http://speedtest.lafibre.info/speedtest/random2000x2000.jpg?x=".date('U'), //"cableinfo" => "http://ports.cable-info.net:43210/test.php",
"bbox" => "http://speed.degrouptest.com/ookla/speedtest/random1500x1500.jpg?x=".date('U') "bbox" => "http://speed.degrouptest.com/ookla/speedtest/random1500x1500.jpg?x=".date('U')
); );
$labels = array(
"bbox" => "Speedtest.net BBox fibre (ookla)",
"free" => "test-debit.free.fr"
);
//Connexion Mbits (30/100)
$connexion = 35;
// CONFIG ------------------------------------------------------------------ // CONFIG ------------------------------------------------------------------
if ($argc > 1 && $argv[1]=='config'){ if ($argc > 1 && $argv[1]=='config'){
echo "graph_category network echo "graph_category network
graph_title Speed test graph_title Speed test
graph_args --base 1024 graph_args --base 1024
grenouille.label grenouille graph_vlabel DL (MB/s)
grenouille.draw LINE2 grenouille.label Grenouille (NC)
grenouille.type GAUGE
maximum.label Connexion (max)
maximum.type GAUGE
maximum.colour ff0000
maximum.max ".$connexion."00000
"; ";
$order=""; $order="";
foreach ($mire as $label => $url) { foreach ($mire as $label => $url) {
echo "$label.label $label\n"; if (isset($labels[$label]))
echo "$label.label ".$labels[$label]."\n";
else
echo "$label.label $label\n";
echo "$label.draw LINE2\n"; echo "$label.draw LINE2\n";
$order .= " $label"; $order .= " $label";
} }
echo "graph_order grenouille ".trim($order)."\n"; echo "graph_order grenouille ".trim($order)." maximum\n";
exit; exit;
} }
@ -47,43 +63,65 @@ if (is_file($grenouille_csv) ) {
$grenouille = explode("\n",trim(file_get_contents($grenouille_csv))); $grenouille = explode("\n",trim(file_get_contents($grenouille_csv)));
$grenouille = end($grenouille); $grenouille = end($grenouille);
$last_data = explode(";",$grenouille); $last_data = explode(";",$grenouille);
//$date = $last_data[0]; $time = $last_data[1]; $cache['grenouille'] = @ floatval($last_data[2])*1000.0;
//$t = strptime($date.' '.$time,'%d/%m/%Y %H:%M:%S');
//$time = mktime($t['tm_hour'],$t['tm_min'],$t['tm_sec'], $t['tm_mon'],$t['tm_mday'],1900 + $t['tm_year']);
//if ((date('U') - date('U',$time)) < 180) {
$cache['grenouille'] = @ floatval($last_data[2])*1000.0;
//}
} }
$output = "grenouille.value ".round($cache['grenouille'])."\n"; $output = "grenouille.value ".round($cache['grenouille'])."\n";
// SPEED TEST -------------------------------------------------------------- // OUTPUT ------------------------------------------------------------------
$item = 0; $item = 0;
foreach ($mire as $label => $url) { foreach ($mire as $label => $url) {
$cache[$label] = (int) @ $cache[$label]; $cache[$label] = (float) @ $cache[$label];
if ($item == $cache['item']) { $item++;
$before = microtime(true);
$data = file_get_contents($url);
$data = file_get_contents($url);
$after = microtime(true);
$len = strlen($data) * 2;
if (($after - $before) > 0) $output .= "$label.value ".round($cache[$label])."\n";
$cache[$label] = $len / ($after - $before);
else
$cache[$label] = 0;
}
$item++;
$output .= "$label.value ".round($cache[$label])."\n";
} }
$output .= "maximum.value ".round($connexion * 1024 * 1024 / 10)."\n";
echo $output; echo $output;
$cache['item'] = ($cache['item'] + 1) % count($mire); // SPEED TEST --------------------------------------------------------------
//save cache // Background Process
@file_put_contents($cache_file,serialize($cache)); if ($argc == 2 && $argv[1]=='speedtest'){
@chmod ($cache_file, 0666); $item = 0;
@chown($cache_file,'munin'); foreach ($mire as $label => $url) {
$cache[$label] = (float) @ $cache[$label];
if ($item == $cache['item']) {
$data = ""; $timeout = 10;
$before = microtime(true);
while ($timeout > 0 && strlen($data) < 15000000) {
$data .= file_get_contents($url);
$timeout--;
}
$after = microtime(true);
$len = strlen($data);
if (($after - $before) > 0) {
$speed = $len / ($after - $before);
if ($cache[$label] > 0)
$cache[$label] = ($cache[$label] + $speed) / 2;
else
$cache[$label] = $speed;
} else
$cache[$label] = 0;
}
$item++;
}
$cache['item'] = ($cache['item'] + 1) % count($mire);
//save cache for next munin call
@file_put_contents($cache_file,serialize($cache));
@chmod ($cache_file, 0666);
@chown($cache_file,'munin');
}
else
{
//do all speedtests in background
$processes = trim(shell_exec("ps aux | grep php | grep speedtest"));
if (count(explode("\n", $processes)) <= 2) {
shell_exec("nohup ".$argv[0].' speedtest > /dev/null 2>&1 &echo $!');
}
}
?> ?>