manage new apache extended status

This commit is contained in:
garnier-quentin 2019-12-16 18:02:11 +01:00
parent 22be9f084f
commit 69b366ff0f
1 changed files with 41 additions and 24 deletions

View File

@ -26,6 +26,7 @@ use strict;
use warnings; use warnings;
use centreon::plugins::http; use centreon::plugins::http;
use centreon::plugins::statefile; use centreon::plugins::statefile;
use centreon::plugins::misc;
sub new { sub new {
my ($class, %options) = @_; my ($class, %options) = @_;
@ -33,22 +34,22 @@ sub new {
bless $self, $class; bless $self, $class;
$options{options}->add_options(arguments => { $options{options}->add_options(arguments => {
"hostname:s" => { name => 'hostname' }, 'hostname:s' => { name => 'hostname' },
"port:s" => { name => 'port', }, 'port:s' => { name => 'port', },
"proto:s" => { name => 'proto' }, 'proto:s' => { name => 'proto' },
"urlpath:s" => { name => 'url_path', default => "/server-status/?auto" }, 'urlpath:s' => { name => 'url_path', default => "/server-status/?auto" },
"credentials" => { name => 'credentials' }, 'credentials' => { name => 'credentials' },
"basic" => { name => 'basic' }, 'basic' => { name => 'basic' },
"username:s" => { name => 'username' }, 'username:s' => { name => 'username' },
"password:s" => { name => 'password' }, 'password:s' => { name => 'password' },
"header:s@" => { name => 'header' }, 'header:s@' => { name => 'header' },
"warning:s" => { name => 'warning' }, 'warning:s' => { name => 'warning' },
"critical:s" => { name => 'critical' }, 'critical:s' => { name => 'critical' },
"warning-bytes:s" => { name => 'warning_bytes' }, 'warning-bytes:s' => { name => 'warning_bytes' },
"critical-bytes:s" => { name => 'critical_bytes' }, 'critical-bytes:s' => { name => 'critical_bytes' },
"warning-access:s" => { name => 'warning_access' }, 'warning-access:s' => { name => 'warning_access' },
"critical-access:s" => { name => 'critical_access' }, 'critical-access:s' => { name => 'critical_access' },
"timeout:s" => { name => 'timeout' }, 'timeout:s' => { name => 'timeout' },
}); });
$self->{http} = centreon::plugins::http->new(%options); $self->{http} = centreon::plugins::http->new(%options);
$self->{statefile_value} = centreon::plugins::statefile->new(%options); $self->{statefile_value} = centreon::plugins::statefile->new(%options);
@ -92,19 +93,35 @@ sub run {
my ($self, %options) = @_; my ($self, %options) = @_;
my $webcontent = $self->{http}->request(); my $webcontent = $self->{http}->request();
#Total accesses: 7323 - Total Traffic: 243.7 MB - Total Duration: 7175675
#CPU Usage: u1489.98 s1118.39 cu0 cs0 - .568% CPU load
#.0159 requests/sec - 555 B/second - 34.1 kB/request - 979.882 ms/request
my ($rPerSec, $bPerReq, $total_access, $total_bytes, $avg_bPerSec); my ($rPerSec, $bPerReq, $total_access, $total_bytes, $avg_bPerSec);
$total_access = $1 if ($webcontent =~ /^Total Accesses:\s+([^\s]+)/mi); $total_access = $1 if ($webcontent =~ /^Total Accesses:\s+([^\s]+)/mi);
$total_bytes = $1 * 1024 if ($webcontent =~ /^Total kBytes:\s+([^\s]+)/mi); $total_bytes = $1 * 1024 if ($webcontent =~ /^Total kBytes:\s+([^\s]+)/mi);
if ($webcontent =~ /Total\s+Traffic:\s+(\S+)\s+(.|)B\s+/mi) {
$total_bytes = centreon::plugins::misc::convert_bytes(value => $1, unit => $2 . 'B');
}
$rPerSec = $1 if ($webcontent =~ /^ReqPerSec:\s+([^\s]+)/mi); $rPerSec = $1 if ($webcontent =~ /^ReqPerSec:\s+([^\s]+)/mi);
# Need a little time to init if ($webcontent =~ /^(\S+)\s+requests\/sec/mi) {
if ($webcontent =~ /^BytesPerReq:\s+([^\s]+)/mi) { $rPerSec = $1;
$bPerReq = $1 $rPerSec = '0' . $rPerSec if ($rPerSec =~ /^\./);
} else {
$bPerReq = 0;
} }
# Need a little time to init
$bPerReq = $1 if ($webcontent =~ /^BytesPerReq:\s+([^\s]+)/mi);
if ($webcontent =~ /(\S+)\s+(.|)B\/request/mi) {
$bPerReq = centreon::plugins::misc::convert_bytes(value => $1, unit => $2 . 'B');
}
$avg_bPerSec = $1 if ($webcontent =~ /^BytesPerSec:\s+([^\s]+)/mi); $avg_bPerSec = $1 if ($webcontent =~ /^BytesPerSec:\s+([^\s]+)/mi);
if ($webcontent =~ /(\S+)\s+(.|)B\/second/mi) {
$avg_bPerSec = centreon::plugins::misc::convert_bytes(value => $1, unit => $2 . 'B');
}
if (!defined($avg_bPerSec)) { if (!defined($avg_bPerSec)) {
$self->{output}->add_option_msg(short_msg => "Apache 'ExtendedStatus' option is off."); $self->{output}->add_option_msg(short_msg => "Apache 'ExtendedStatus' option is off.");