php RRD График плавающие значения вместо целых
Я создаю граф Rrd, и я сталкиваюсь с 2 проблемами.
Проблема 1: числа, которые я печатаю, являются целыми числами без десятичных знаков, хотя, когда они печатаются, появляются десятичные дроби. Это действительно сбивает с толку. Поэтому я посмотрел онлайн на rrdgraph_graph и, хотя я использую правильный синтаксис и не применяю никаких вычислений, я все равно получаю плавающие значения вместо целых.
По данным официального сайта: %s place this after %le, %lf or %lg. This will be replaced by the appropriate SI magnitude unit and the value will be scaled accordingly (123456 -> 123.456 k).
Я приложил фотографию в качестве образца вывода. Я также предоставил рабочий пример кода, так что если кто-то понимает, что RRD может просмотреть возможные ошибки.
Проблема 2: я пытался добавить на свой график VRULE:time#color[:legend][:dashes[=on_s[,off_s[,on_s,off_s]...]][:dash-offset=offset]]
функции и на основе онлайн-инструкций я могу предоставить время. Поскольку мой график смещается, я планировал сделать время (значение) - 1800 сек. Я хотел поместить вертикальную линию в середине графика, чтобы я мог просматривать приблизительно среднее значение по 30 минутам. Когда я применяю такой формат, я получаю эту ошибку:
<b>Graph error: </b>parameter '1400274668-1800' does not represent time in line VRULE:1400274668-1800#0000CD:Half way values
Когда я снимаю вычитание все работает нормально. Есть ли способ создать эту линию в середине моего графика?
<?php
$file = "snmp";
$rrdFile = dirname(__FILE__) . "/".$file.".rrd";
$in = "losses";
$png = "/home/linux/Desktop/";
$in_min = "vdef_in_min";
$in_max = "vdef_in_max";
$in_lst = "vdef_in_lst";
$in_av = "vdef_in_av";
$title = "Losses RRD::Graph";
$output = array("1h","1d");
$step = 5;
$heartbeat = 2 * $step;
while (1) {
sleep (1);
$options = array(
"--start","now -15s",
"--step", "".$step."",
"DS:".$in.":GAUGE:".$heartbeat.":0:U",
"RRA:LAST:0.5:1:3600",
"RRA:MIN:0.5:1:3600",
"RRA:MAX:0.5:1:3600",
"RRA:AVERAGE:0.5:6:600",
"RRA:LAST:0.5:300:288",
"RRA:MIN:0.5:300:288",
"RRA:MAX:0.5:300:288`",
"RRA:AVERAGE:0.5:600:144"
);
if ( !isset( $create ) ) {
$create = rrd_create(
"".$rrdFile."",
$options
);
if ( $create === FALSE ) {
echo "Creation error: ".rrd_error()."\n";
}
}
$t = time();
$losses = rand(0, 150);
$update = rrd_update(
"".$rrdFile."",
array(
"".$t.":".$losses.""
)
);
if ($update === FALSE) {
echo "Update error: ".rrd_error()."\n";
}
date_default_timezone_set('Europe/Stockholm');
$timezone = new DateTime(NULL, new DateTimeZone('Europe/Stockholm'));
$date = date('l jS \of F Y h\\:i\\:s A' , $timezone->format('U'));
$comment = "RRD last updated:".$date;
$comment = str_replace( ":", "\\:", $comment );
$graph = "Graph last updated:".$date;
$graph = str_replace( ":", "\\:", $graph );
foreach ($output as $test) {
$final = array(
"--start","end - ".$test."",
"--end", "".$t."",
"--title=".$file." RRD::Graph with - ".$test." Periods",
"--vertical-label=Bytes(s)/sec",
"--right-axis-label=latency(ms)",
"--alt-y-grid", "--rigid",
"--width", "800", "--height", "500",
"--lower-limit=0",
"--no-gridfit",
"--slope-mode",
"DEF:".$in."_def=".$file.".rrd:".$in.":LAST",
"CDEF:inbytes=".$in."_def",
"VDEF:".$in_lst."=inbytes,LAST",
"VDEF:".$in_min."=inbytes,MINIMUM",
"VDEF:".$in_max."=inbytes,MAXIMUM",
"VDEF:".$in_av."=inbytes,AVERAGE",
"COMMENT:\\n",
"LINE2:".$in."_def#FF0000:".$in."",
"GPRINT:".$in_min.": Minimum\:%6.2lf %S",
"GPRINT:".$in_max.":Maximum\:%6.2lf %S",
"GPRINT:".$in_lst.":Last\:%6.2lf %s",
"GPRINT:".$in_av.":Average\:%6.2lf %s",
"COMMENT:\\n",
"VRULE:".$t."#0000CD:Half way values",
"COMMENT:\\n",
"HRULE:50#FFFF00:Maximum value",
"COMMENT:\\n",
"COMMENT: ",
"COMMENT:\\n",
"COMMENT:".$comment."\\r",
"COMMENT:".$graph."\\r"
);
$outputPngFile = rrd_graph(
"".$png."".$test.".png",
$final
);
if ($outputPngFile === FALSE) {
echo "<b>Graph error: </b>".rrd_error()."\n";
}
}
$debug = rrd_lastupdate (
"".$rrdFile.""
);
if ($debug === FALSE) {
echo "<b>Graph result error: </b>".rrd_error()."\n";
}
var_dump ($debug);
}
?>
1 ответ
Ответом на вашу первую проблему является почти наверняка нормализация данных. Поскольку вы не обновляете RRD точно на границе шага каждый раз, представленные значения данных нормализуются к границе шага, что приводит к десятичным значениям. Чтобы понять это, прочитайте отличную статью Алекса ван ден Богардта на эту тему.
Ваша вторая проблема заключается в том, что вы просто не можете использовать объявление VRULE таким образом. Первым параметром VRULE может быть либо число, либо переменная VDEF, но это не может быть формула. Следовательно, VRULE:12345678#0000CD:Foo
хорошо, как есть VRULE:vdefname#FF00FF:Bar
, Однако вы не можете использовать VRULE:123456-123#0000CD:No
, Сделайте расчет раньше, вот так:
"VRULE:".($t-1800)."#0000CD:Half way values",
... и это должно привести к правильному синтаксису.