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",

... и это должно привести к правильному синтаксису.

Другие вопросы по тегам