added the ability, in the alerts of 'ambsens.pm', to support a range of two values separated by a dash in the threshold #221

This commit is contained in:
Jordi Sanfeliu 2019-04-23 16:13:41 +02:00
parent 6a63750d74
commit 19eff008fb
3 changed files with 47 additions and 5 deletions

View File

@ -3,7 +3,9 @@
- Added a complete graph to support PHP-FPM statistics ('phpfpm.pm'). [#167] - Added a complete graph to support PHP-FPM statistics ('phpfpm.pm'). [#167]
- Added a warning if a process vanished during the accouting in 'process.pm' - Added a warning if a process vanished during the accouting in 'process.pm'
- Added the ability, in the alerts of 'gensens.pm', to support a range of two - Added the ability, in the alerts of 'gensens.pm', to support a range of two
values separated by a dash in the threshold. [#221] values, separated by a dash, in the threshold. [#221]
- Added the ability, in the alerts of 'ambsens.pm', to support a range of two
values, separated by a dash, in the threshold. [#221]
- Fixed the copyright year in 'monitorix.cgi'. - Fixed the copyright year in 'monitorix.cgi'.
- Fixed in 'mail.pm to use the option 'mail_log' instead the hard coded path I - Fixed in 'mail.pm to use the option 'mail_log' instead the hard coded path I
forgot to remove when adding the Exim support. forgot to remove when adding the Exim support.

View File

@ -161,9 +161,9 @@ sub ambsens_update {
my $script = trim($al[2]); my $script = trim($al[2]);
my $when = lc(trim($al[3] || "")); my $when = lc(trim($al[3] || ""));
my @range = split('-', $threshold); my @range = split('-', $threshold);
$when = "above" if !$when; # 'above' is the default
$threshold = 0 if !$threshold; $threshold = 0 if !$threshold;
if(scalar(@range) == 1) { if(scalar(@range) == 1) {
$when = "above" if !$when; # 'above' is the default
if($when eq "above" && $val < $threshold) { if($when eq "above" && $val < $threshold) {
$config->{ambsens_hist_alerts}->{$str} = 0; $config->{ambsens_hist_alerts}->{$str} = 0;
} elsif($when eq "below" && $val > $threshold) { } elsif($when eq "below" && $val > $threshold) {
@ -187,7 +187,43 @@ sub ambsens_update {
} }
} }
} elsif(scalar(@range) == 2) { } elsif(scalar(@range) == 2) {
logger("$myself: range values are not supported yet."); if($when) {
logger("$myself: the forth parameter ('$when') in '$str' is irrelevant when there are range values defined.");
}
if($range[0] == $range[1]) {
logger("$myself: ERROR: range values are identical.");
} else {
if($val <= $range[0]) {
$config->{ambsens_hist_alerts}->{$str}->{above} = 0;
if($val < $range[0] && !$config->{ambsens_hist_alerts}->{$str}->{below}) {
$config->{ambsens_hist_alerts}->{$str}->{below} = time;
}
}
if($val >= $range[1]) {
$config->{ambsens_hist_alerts}->{$str}->{below} = 0;
if($val > $range[1] && !$config->{ambsens_hist_alerts}->{$str}->{above}) {
$config->{ambsens_hist_alerts}->{$str}->{above} = time;
}
}
if($config->{ambsens_hist_alerts}->{$str}->{below} > 0 && (time - $config->{ambsens_hist_alerts}->{$str}->{below}) >= $timeintvl) {
if(-x $script) {
logger("$myself: alert on Ambient Sensor ($str): executing script '$script'.");
system($script . " " . $timeintvl . " " . $threshold . " " . $val);
} else {
logger("$myself: ERROR: script '$script' doesn't exist or don't has execution permissions.");
}
$config->{ambsens_hist_alerts}->{$str}->{below} = time;
}
if($config->{ambsens_hist_alerts}->{$str}->{above} > 0 && (time - $config->{ambsens_hist_alerts}->{$str}->{above}) >= $timeintvl) {
if(-x $script) {
logger("$myself: alert on Ambient Sensor ($str): executing script '$script'.");
system($script . " " . $timeintvl . " " . $threshold . " " . $val);
} else {
logger("$myself: ERROR: script '$script' doesn't exist or don't has execution permissions.");
}
$config->{ambsens_hist_alerts}->{$str}->{above} = time;
}
}
} else { } else {
logger("$myself: ERROR: invalid threshold value '$threshold'"); logger("$myself: ERROR: invalid threshold value '$threshold'");
} }

View File

@ -1169,11 +1169,11 @@ This optional list enables the alert capabilities for this graph and complements
.P .P
The \fItime interval\fP is the period of time (in seconds) that the \fIthreshold\fP needs to be exceeded before the external script is executed. The \fItime interval\fP is the period of time (in seconds) that the \fIthreshold\fP needs to be exceeded before the external script is executed.
.P .P
The \fIthreshold\fP is the value (either temperature or HZ) that needs to be reached or exceeded within the specified time in \fItime interval\fP to execute the external script. The \fIthreshold\fP is the value (either temperature or HZ) that needs to be reached or exceeded within the specified time in \fItime interval\fP to execute the external script. It can be specified as a unique value or as a range of two values separated by a dash.
.P .P
The \fIscript\fP is the full path name of the script that will be executed by this alert. The \fIscript\fP is the full path name of the script that will be executed by this alert.
.P .P
The \fIwhen\fP value specifies when the alert must be triggered (\fIabove\fP or \fIbelow\fP) the threshold, being \fIabove\fP the default value when it's not specified. The \fIwhen\fP value specifies when the alert must be triggered (\fIabove\fP or \fIbelow\fP) the threshold, being \fIabove\fP the default value when it's not specified. This forth parameter is only relevant when the \fIthreshold\fP value is not a range.
.P .P
Each defined sensor has its own alert. Each defined sensor has its own alert.
.P .P
@ -1187,6 +1187,8 @@ The following is an example of an alert defined for the first temperature sensor
temp0 = 3600, 40, /path/to/script.sh, above temp0 = 3600, 40, /path/to/script.sh, above
.br .br
temp1 = 3600, 10, /path/to/script.sh, below temp1 = 3600, 10, /path/to/script.sh, below
.br
temp2 = 3600, 40-60, /path/to/script.sh
.br .br
</alerts> </alerts>
.P .P
@ -1195,6 +1197,8 @@ The first alert means that if the value of the sensor temp0 exceeds above 40 dur
.P .P
The second alert means that if the value of the sensor temp1 exceeds below 10 during at least one hour (3600 seconds) the script in \fI/path/to/script.sh\fP will be executed. The second alert means that if the value of the sensor temp1 exceeds below 10 during at least one hour (3600 seconds) the script in \fI/path/to/script.sh\fP will be executed.
.P .P
The third alert means that if the value of the sensor temp2 either exceeds below 40 or above of 60 during at least one hour (3600 seconds) the script in \fI/path/to/script.sh\fP will be executed.
.P
The external script will receive the following arguments: The external script will receive the following arguments:
.P .P
.RS .RS