From 4f33fd727c3510edc296229fadcc7f06e0e6103c Mon Sep 17 00:00:00 2001 From: Andreas Bachlechner <62039342+bachandi@users.noreply.github.com> Date: Fri, 24 Sep 2021 16:41:21 +0200 Subject: [PATCH 1/3] Add options to use nan instead of 0 for missing data and to show gaps only if all data are invalid. - use_nan_for_missing_data = y - gap_on_all_nan = y This is useful if missing data could otherwise be misinterpreted as valid. Default behaviour does not change. --- lib/ipmi.pm | 10 ++++++---- man/man5/monitorix.conf.5 | 23 +++++++++++++++++++++++ 2 files changed, 29 insertions(+), 4 deletions(-) diff --git a/lib/ipmi.pm b/lib/ipmi.pm index 90621ec..d11eee7 100644 --- a/lib/ipmi.pm +++ b/lib/ipmi.pm @@ -134,6 +134,7 @@ sub ipmi_update { my $rrd = $config->{base_lib} . $package . ".rrd"; my $ipmi = $config->{ipmi}; my $args = $ipmi->{extra_args} || ""; + my $use_nan_for_missing_data = lc(($ipmi->{use_nan_for_missing_data} || "")) eq "y" ? 1 : 0; my @sens; @@ -153,8 +154,7 @@ sub ipmi_update { my $e2 = 0; foreach my $i (split(',', $ipmi->{desc}->{$e})) { my $unit; - - $sens[$e][$e2] = 0 unless defined $sens[$e][$e2]; + $sens[$e][$e2] = ($use_nan_for_missing_data ? "NaN" : 0) unless defined $sens[$e][$e2]; $str = trim($i); $unit = $ipmi->{units}->{$e}; foreach(@data) { @@ -214,6 +214,7 @@ sub ipmi_cgi { my @output; my $ipmi = $config->{ipmi}; + my $gap_on_all_nan = lc(($ipmi->{gap_on_all_nan} || "")) eq "y" ? 1 : 0; my @rigid = split(',', ($ipmi->{rigid} || "")); my @limit = split(',', ($ipmi->{limit} || "")); my $tf = $cgi->{tf}; @@ -400,6 +401,7 @@ sub ipmi_cgi { } ($width, $height) = split('x', $config->{graph_size}->{medium}); $str = substr(trim($sl[$n]), 0, 25); + my $cdef_allvalues = $gap_on_all_nan ? "CDEF:allvalues=s1,UN,0,1,IF,s2,UN,0,1,IF,s3,UN,0,1,IF,s4,UN,0,1,IF,s5,UN,0,1,IF,s6,UN,0,1,IF,s7,UN,0,1,IF,s8,UN,0,1,IF,s9,UN,0,1,IF,+,+,+,+,+,+,+,+,0,GT,1,UNKN,IF" : "CDEF:allvalues=s1,s2,s3,s4,s5,s6,s7,s8,s9,+,+,+,+,+,+,+,+"; $pic = $rrd{$version}->("$IMG_DIR" . "$IMG[$n]", "--title=$str ($tf->{nwhen}$tf->{twhen})", "--start=-$tf->{nwhen}$tf->{twhen}", @@ -421,7 +423,7 @@ sub ipmi_cgi { "DEF:s7=$rrd:ipmi" . $n . "_s7:AVERAGE", "DEF:s8=$rrd:ipmi" . $n . "_s8:AVERAGE", "DEF:s9=$rrd:ipmi" . $n . "_s9:AVERAGE", - "CDEF:allvalues=s1,s2,s3,s4,s5,s6,s7,s8,s9,+,+,+,+,+,+,+,+", + $cdef_allvalues, @CDEF, @tmp); $err = RRDs::error; @@ -449,7 +451,7 @@ sub ipmi_cgi { "DEF:s7=$rrd:ipmi" . $n . "_s7:AVERAGE", "DEF:s8=$rrd:ipmi" . $n . "_s8:AVERAGE", "DEF:s9=$rrd:ipmi" . $n . "_s9:AVERAGE", - "CDEF:allvalues=s1,s2,s3,s4,s5,s6,s7,s8,s9,+,+,+,+,+,+,+,+", + $cdef_allvalues, @CDEF, @tmpz); $err = RRDs::error; diff --git a/man/man5/monitorix.conf.5 b/man/man5/monitorix.conf.5 index e334242..c1e43ba 100644 --- a/man/man5/monitorix.conf.5 +++ b/man/man5/monitorix.conf.5 @@ -1221,6 +1221,29 @@ This is the number of graphs that will be put in a row. .P Default value: \fI2\fP .RE + +.P +.RE +.RE +.BI use_nan_for_missing_data +.RS +This option, when enabled via \fIy\fP, shows \fnan\fP values for missing data instead of \f0\fP. This is useful when \f0\fP could be mistaken for valid data. +.P +Default value: \fIn\fP +.RE +.P +.RE +.RE +.BI gap_on_all_nan +.RS +This option, when enabled via \fIy\fP, combined with the \fIshow_gaps\fP option shows gaps only if all data points are \fInan\fP instead of requiring only one to be \fInan\fP for a gap. This can be useful if not all sensor data are required for normal operation. +.P +Default value: \fIn\fP +.RE + + + + .P .BI extra_args .RS From 4b6b3bfc082a505556b8d8c1b8deaf4aa75f398a Mon Sep 17 00:00:00 2001 From: Andreas Bachlechner <62039342+bachandi@users.noreply.github.com> Date: Thu, 7 Oct 2021 18:52:25 +0200 Subject: [PATCH 2/3] Only create the nan once per loop. --- lib/ipmi.pm | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/lib/ipmi.pm b/lib/ipmi.pm index d11eee7..0dd815f 100644 --- a/lib/ipmi.pm +++ b/lib/ipmi.pm @@ -149,12 +149,14 @@ sub ipmi_update { my @data = ; close(IN); + my $nan = 0+"nan"; # To generate a 'nan' value + my $e = 0; while($e < scalar(my @sl = split(',', $ipmi->{list}))) { my $e2 = 0; foreach my $i (split(',', $ipmi->{desc}->{$e})) { my $unit; - $sens[$e][$e2] = ($use_nan_for_missing_data ? "NaN" : 0) unless defined $sens[$e][$e2]; + $sens[$e][$e2] = ($use_nan_for_missing_data ? $nan : 0) unless defined $sens[$e][$e2]; $str = trim($i); $unit = $ipmi->{units}->{$e}; foreach(@data) { From 8231a18fb16bd540dcd50c6e91fc6d928c9728ed Mon Sep 17 00:00:00 2001 From: Andreas Bachlechner <62039342+bachandi@users.noreply.github.com> Date: Fri, 8 Oct 2021 01:48:58 +0200 Subject: [PATCH 3/3] Change nan creation location --- lib/ipmi.pm | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/lib/ipmi.pm b/lib/ipmi.pm index 0dd815f..0066777 100644 --- a/lib/ipmi.pm +++ b/lib/ipmi.pm @@ -149,14 +149,12 @@ sub ipmi_update { my @data = ; close(IN); - my $nan = 0+"nan"; # To generate a 'nan' value - my $e = 0; while($e < scalar(my @sl = split(',', $ipmi->{list}))) { my $e2 = 0; foreach my $i (split(',', $ipmi->{desc}->{$e})) { my $unit; - $sens[$e][$e2] = ($use_nan_for_missing_data ? $nan : 0) unless defined $sens[$e][$e2]; + $sens[$e][$e2] = ($use_nan_for_missing_data ? (0+"nan") : 0) unless defined $sens[$e][$e2]; $str = trim($i); $unit = $ipmi->{units}->{$e}; foreach(@data) {