enhance php

This commit is contained in:
garnier-quentin 2021-01-25 11:04:45 +01:00
parent 9e9298c0d2
commit d9ee77c657
3 changed files with 173 additions and 168 deletions

View File

@ -27,104 +27,11 @@ use warnings;
use centreon::plugins::http;
use Digest::MD5 qw(md5_hex);
sub set_counters {
my ($self, %options) = @_;
$self->{maps_counters_type} = [
{ name => 'fcache', type => 0, cb_prefix_output => 'prefix_output' }
];
$self->{maps_counters}->{fcache} = [
{ label => 'request-rate', nlabel => 'requests.persecond', set => {
key_values => [ { name => 'rr' } ],
output_template => 'Request Rate (global): %.2f',
perfdatas => [
{ label => 'request_rate', template => '%.2f',
unit => 'r/s', min => 0 }
]
}
},
{ label => 'request-rate-now', nlabel => 'requests.now.persecond', set => {
key_values => [ { name => 'hits', diff => 1 }, { name => 'misses', diff => 1 } ],
closure_custom_calc => $self->can('custom_rr_calc'),
output_template => 'Request Rate : %.2f', output_error_template => 'Request Rate : %s',
output_use => 'rr_now', threshold_use => 'rr_now',
perfdatas => [
{ label => 'request_rate_now', template => '%.2f',
unit => 'r/s', min => 0 }
]
}
},
{ label => 'hit-rate', nlabel => 'hits.persecond', set => {
key_values => [ { name => 'hr' } ],
output_template => 'Hit Rate (global): %.2f',
perfdatas => [
{ label => 'hit_rate',template => '%.2f',
unit => 'r/s', min => 0 }
]
}
},
{ label => 'hit-rate-now', nlabel => 'hits.persecond', set => {
key_values => [ { name => 'hits', diff => 1 } ],
closure_custom_calc => $self->can('custom_hr_calc'),
output_template => 'Hit Rate : %.2f', output_error_template => 'Hit Rate : %s',
output_use => 'hr_now', threshold_use => 'hr_now',
perfdatas => [
{ label => 'hit_rate_now', template => '%.2f',
unit => 'r/s', min => 0 }
]
}
},
{ label => 'miss-rate', nlabel => 'misses.persecond', set => {
key_values => [ { name => 'mr' } ],
output_template => 'Miss Rate (global): %.2f',
perfdatas => [
{ label => 'miss_rate',template => '%.2f',
unit => 'r/s', min => 0 }
]
}
},
{ label => 'miss-rate-now', nlabel => 'misses.now.persecond', set => {
key_values => [ { name => 'misses', diff => 1 } ],
closure_custom_calc => $self->can('custom_mr_calc'),
output_template => 'Miss Rate : %.2f', output_error_template => 'Miss Rate : %s',
output_use => 'mr_now', threshold_use => 'mr_now',
perfdatas => [
{ label => 'miss_rate_now', value => 'mr_now', template => '%.2f',
unit => 'r/s', min => 0 }
]
}
},
{ label => 'hit-percent', nlabel => 'hits.percentage', set => {
key_values => [ { name => 'hits' }, { name => 'misses' } ],
closure_custom_calc => $self->can('custom_hit_percent_calc'),
output_template => 'Hit Ratio (global) : %.2f %%', output_error_template => 'Hit Ratio (global): %s',
output_use => 'hit_ratio', threshold_use => 'hit_ratio',
perfdatas => [
{ label => 'hit_ratio', value => 'hit_ratio', template => '%.2f',
unit => '%', min => 0, max => 100 }
]
}
},
{ label => 'hit-percent-now', nlabel => 'hits.now.percentage', set => {
key_values => [ { name => 'hits', diff => 1 }, { name => 'misses', diff => 1 } ],
closure_custom_calc => $self->can('custom_hit_percent_now_calc'),
output_template => 'Hit Ratio : %.2f %%', output_error_template => 'Hit Ratio : %s',
output_use => 'hit_ratio_now', threshold_use => 'hit_ratio_now',
perfdatas => [
{ label => 'hit_ratio_now', value => 'hit_ratio_now', template => '%.2f',
unit => '%', min => 0, max => 100 }
]
}
}
];
}
sub custom_rr_calc {
my ($self, %options) = @_;
my $total = ($options{new_datas}->{$self->{instance} . '_hits'} - $options{old_datas}->{$self->{instance} . '_hits'})
+ ($options{new_datas}->{$self->{instance} . '_misses'} - $options{old_datas}->{$self->{instance} . '_misses'});
if ($total == 0) {
$self->{error_msg} = "skipped";
return -2;
@ -191,7 +98,100 @@ sub custom_hit_percent_calc {
sub prefix_output {
my ($self, %options) = @_;
return "Apc File Cache Information ";
return 'Apc File Cache Information ';
}
sub set_counters {
my ($self, %options) = @_;
$self->{maps_counters_type} = [
{ name => 'fcache', type => 0, cb_prefix_output => 'prefix_output' }
];
$self->{maps_counters}->{fcache} = [
{ label => 'request-rate', nlabel => 'filecache.requests.persecond', set => {
key_values => [ { name => 'rr' } ],
output_template => 'Request Rate (global): %.2f',
perfdatas => [
{ label => 'request_rate', template => '%.2f',
unit => 'r/s', min => 0 }
]
}
},
{ label => 'request-rate-now', nlabel => 'filecache.requests.now.persecond', set => {
key_values => [ { name => 'hits', diff => 1 }, { name => 'misses', diff => 1 } ],
closure_custom_calc => $self->can('custom_rr_calc'),
output_template => 'Request Rate : %.2f', output_error_template => 'Request Rate : %s',
output_use => 'rr_now', threshold_use => 'rr_now',
perfdatas => [
{ label => 'request_rate_now', template => '%.2f',
unit => 'r/s', min => 0 }
]
}
},
{ label => 'hit-rate', nlabel => 'filecache.hits.persecond', set => {
key_values => [ { name => 'hr' } ],
output_template => 'Hit Rate (global): %.2f',
perfdatas => [
{ label => 'hit_rate',template => '%.2f',
unit => 'r/s', min => 0 }
]
}
},
{ label => 'hit-rate-now', nlabel => 'filecache.hits.now.persecond', set => {
key_values => [ { name => 'hits', diff => 1 } ],
closure_custom_calc => $self->can('custom_hr_calc'),
output_template => 'Hit Rate : %.2f', output_error_template => 'Hit Rate : %s',
output_use => 'hr_now', threshold_use => 'hr_now',
perfdatas => [
{ label => 'hit_rate_now', template => '%.2f',
unit => 'r/s', min => 0 }
]
}
},
{ label => 'miss-rate', nlabel => 'filecache.misses.persecond', set => {
key_values => [ { name => 'mr' } ],
output_template => 'Miss Rate (global): %.2f',
perfdatas => [
{ label => 'miss_rate',template => '%.2f',
unit => 'r/s', min => 0 }
]
}
},
{ label => 'miss-rate-now', nlabel => 'filecache.misses.now.persecond', set => {
key_values => [ { name => 'misses', diff => 1 } ],
closure_custom_calc => $self->can('custom_mr_calc'),
output_template => 'Miss Rate : %.2f', output_error_template => 'Miss Rate : %s',
output_use => 'mr_now', threshold_use => 'mr_now',
perfdatas => [
{ label => 'miss_rate_now', value => 'mr_now', template => '%.2f',
unit => 'r/s', min => 0 }
]
}
},
{ label => 'hit-percent', nlabel => 'filecache.hits.percentage', set => {
key_values => [ { name => 'hits' }, { name => 'misses' } ],
closure_custom_calc => $self->can('custom_hit_percent_calc'),
output_template => 'Hit Ratio (global) : %.2f %%', output_error_template => 'Hit Ratio (global): %s',
output_use => 'hit_ratio', threshold_use => 'hit_ratio',
perfdatas => [
{ label => 'hit_ratio', value => 'hit_ratio', template => '%.2f',
unit => '%', min => 0, max => 100 }
]
}
},
{ label => 'hit-percent-now', nlabel => 'filecache.hits.now.percentage', set => {
key_values => [ { name => 'hits', diff => 1 }, { name => 'misses', diff => 1 } ],
closure_custom_calc => $self->can('custom_hit_percent_now_calc'),
output_template => 'Hit Ratio : %.2f %%', output_error_template => 'Hit Ratio : %s',
output_use => 'hit_ratio_now', threshold_use => 'hit_ratio_now',
perfdatas => [
{ label => 'hit_ratio_now', value => 'hit_ratio_now', template => '%.2f',
unit => '%', min => 0, max => 100 }
]
}
}
];
}
sub new {
@ -200,15 +200,15 @@ sub new {
bless $self, $class;
$options{options}->add_options(arguments => {
"hostname:s" => { name => 'hostname' },
"port:s" => { name => 'port', },
"proto:s" => { name => 'proto' },
"urlpath:s" => { name => 'url_path', default => "/apc.php" },
"credentials" => { name => 'credentials' },
"basic" => { name => 'basic' },
"username:s" => { name => 'username' },
"password:s" => { name => 'password' },
"timeout:s" => { name => 'timeout', default => 30 },
'hostname:s' => { name => 'hostname' },
'port:s' => { name => 'port', },
'proto:s' => { name => 'proto' },
'urlpath:s' => { name => 'url_path', default => "/apc.php" },
'credentials' => { name => 'credentials' },
'basic' => { name => 'basic' },
'username:s' => { name => 'username' },
'password:s' => { name => 'password' },
'timeout:s' => { name => 'timeout', default => 30 }
});
$self->{http} = centreon::plugins::http->new(%options);
@ -225,9 +225,9 @@ sub check_options {
sub manage_selection {
my ($self, %options) = @_;
my $webcontent = $self->{http}->request();
$self->{fcache} = {};
$self->{fcache}->{hits} = $webcontent =~ /File Cache Information.*?Hits.*?(\d+)/msi ? $1 : undef;
$self->{fcache}->{misses} = $webcontent =~ /File Cache Information.*?Misses.*?(\d+)/msi ? $1 : undef;
@ -235,8 +235,8 @@ sub manage_selection {
$self->{fcache}->{hr} = $webcontent =~ /File Cache Information.*?Hit Rate.*?([0-9\.]+)/msi ? $1 : undef;
$self->{fcache}->{mr} = $webcontent =~ /File Cache Information.*?Miss Rate.*?([0-9\.]+)/msi ? $1 : undef;
$self->{fcache}->{ir} = $webcontent =~ /File Cache Information.*?Insert Rate.*?([0-9\.]+)/msi ? $1 : undef;
$self->{cache_name} = "apc_" . $self->{mode} . '_' . $self->{option_results}->{hostname} . '_' . $self->{http}->get_port() . '_' .
$self->{cache_name} = 'apc_' . $self->{mode} . '_' . $self->{option_results}->{hostname} . '_' . $self->{http}->get_port() . '_' .
(defined($self->{option_results}->{filter_counters}) ? md5_hex($self->{option_results}->{filter_counters}) : md5_hex('all'));
}

View File

@ -45,10 +45,12 @@ sub custom_used_output {
my ($used_value, $used_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{used});
my ($free_value, $free_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{free});
return sprintf("Memory Usage Total: %s Used: %s (%.2f%%) Free: %s (%.2f%%)",
$total_value . " " . $total_unit,
$used_value . " " . $used_unit, $self->{result_values}->{used_prct},
$free_value . " " . $free_unit, $self->{result_values}->{free_prct});
return sprintf(
"Memory Usage Total: %s Used: %s (%.2f%%) Free: %s (%.2f%%)",
$total_value . " " . $total_unit,
$used_value . " " . $used_unit, $self->{result_values}->{used_prct},
$free_value . " " . $free_unit, $self->{result_values}->{free_prct}
);
}
sub prefix_output {
@ -73,8 +75,8 @@ sub set_counters {
output_error_template => 'Memory Usage: %s',
perfdatas => [
{ label => 'used', template => '%d',
unit => 'B', min => 0, max => 'total', threshold_total => 'total' },
unit => 'B', min => 0, max => 'total', threshold_total => 'total' }
]
}
},
{ label => 'fragmentation', nlabel => 'memory.fragmentation.percentage', set => {
@ -96,19 +98,19 @@ sub new {
bless $self, $class;
$options{options}->add_options(arguments => {
"hostname:s" => { name => 'hostname' },
"port:s" => { name => 'port', },
"proto:s" => { name => 'proto' },
"urlpath:s" => { name => 'url_path', default => "/apc.php" },
"credentials" => { name => 'credentials' },
"basic" => { name => 'basic' },
"username:s" => { name => 'username' },
"password:s" => { name => 'password' },
"timeout:s" => { name => 'timeout', default => 30 },
'hostname:s' => { name => 'hostname' },
'port:s' => { name => 'port', },
'proto:s' => { name => 'proto' },
'urlpath:s' => { name => 'url_path', default => "/apc.php" },
'credentials' => { name => 'credentials' },
'basic' => { name => 'basic' },
'username:s' => { name => 'username' },
'password:s' => { name => 'password' },
'timeout:s' => { name => 'timeout', default => 30 },
});
$self->{http} = centreon::plugins::http->new(%options);
return $self;
}
@ -123,7 +125,7 @@ sub manage_selection {
my ($self, %options) = @_;
my $webcontent = $self->{http}->request();
my ($free, $used);
if ($webcontent =~ /Memory Usage.*?Free:.*?([0-9\.]+)\s*(\S*)/msi) {
$free = centreon::plugins::misc::convert_bytes(value => $1, unit => $2);

View File

@ -29,7 +29,7 @@ use Digest::MD5 qw(md5_hex);
sub custom_active_calc {
my ($self, %options) = @_;
$self->{result_values}->{total} = $options{new_datas}->{$self->{instance} . '_total'};
$self->{result_values}->{active} = $options{new_datas}->{$self->{instance} . '_active'};
$self->{result_values}->{active_prct} = $self->{result_values}->{active} * 100 / $self->{result_values}->{total};
@ -39,24 +39,29 @@ sub custom_active_calc {
sub custom_active_output {
my ($self, %options) = @_;
return sprintf("Active processes: %s (%.2f%%)",
$self->{result_values}->{active},
$self->{result_values}->{active_prct});
return sprintf(
'active processes: %s (%.2f%%)',
$self->{result_values}->{active},
$self->{result_values}->{active_prct}
);
}
sub custom_active_perfdata {
my ($self, %options) = @_;
$self->{output}->perfdata_add(label => 'active',
value => $self->{result_values}->{active},
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{label}, total => $self->{result_values}->{total}, cast_int => 1),
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{label}, total => $self->{result_values}->{total}, cast_int => 1),
min => 0, max => $self->{result_values}->{total});
$self->{output}->perfdata_add(
label => 'active',
nlabel => $self->{nlabel},
value => $self->{result_values}->{active},
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{thlabel}, total => $self->{result_values}->{total}, cast_int => 1),
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{thlabel}, total => $self->{result_values}->{total}, cast_int => 1),
min => 0, max => $self->{result_values}->{total}
);
}
sub custom_idle_calc {
my ($self, %options) = @_;
$self->{result_values}->{total} = $options{new_datas}->{$self->{instance} . '_total'};
$self->{result_values}->{idle} = $options{new_datas}->{$self->{instance} . '_idle'};
$self->{result_values}->{idle_prct} = $self->{result_values}->{idle} * 100 / $self->{result_values}->{total};
@ -66,36 +71,41 @@ sub custom_idle_calc {
sub custom_idle_output {
my ($self, %options) = @_;
return sprintf("Idle processes: %s (%.2f%%)",
$self->{result_values}->{idle},
$self->{result_values}->{idle_prct});
return sprintf(
'idle processes: %s (%.2f%%)',
$self->{result_values}->{idle},
$self->{result_values}->{idle_prct}
);
}
sub custom_idle_perfdata {
my ($self, %options) = @_;
$self->{output}->perfdata_add(label => 'idle',
value => $self->{result_values}->{idle},
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{label}, total => $self->{result_values}->{total}, cast_int => 1),
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{label}, total => $self->{result_values}->{total}, cast_int => 1),
min => 0, max => $self->{result_values}->{total});
$self->{output}->perfdata_add(
label => 'idle',
nlabel => $self->{nlabel},
value => $self->{result_values}->{idle},
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{thlabel}, total => $self->{result_values}->{total}, cast_int => 1),
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{thlabel}, total => $self->{result_values}->{total}, cast_int => 1),
min => 0, max => $self->{result_values}->{total}
);
}
sub prefix_output {
my ($self, %options) = @_;
return "php-fpm ";
return 'php-fpm ';
}
sub set_counters {
my ($self, %options) = @_;
$self->{maps_counters_type} = [
{ name => 'fpm', type => 0, cb_prefix_output => 'prefix_output' }
{ name => 'fpm', type => 0, cb_prefix_output => 'prefix_output', skipped_code => { -10 => 1 } }
];
$self->{maps_counters}->{fpm} = [
{ label => 'active-processes', nlabel => 'processes.active.count', set => {
{ label => 'active-processes', nlabel => 'fpm.processes.active.count', set => {
key_values => [ { name => 'active' }, { name => 'total' } ],
closure_custom_calc => $self->can('custom_active_calc'),
closure_custom_output => $self->can('custom_active_output'),
@ -103,7 +113,7 @@ sub set_counters {
closure_custom_perfdata => => $self->can('custom_active_perfdata')
}
},
{ label => 'idle-processes', nlabel => 'processes.idle.count', set => {
{ label => 'idle-processes', nlabel => 'fpm.processes.idle.count', set => {
key_values => [ { name => 'idle' }, { name => 'total' } ],
closure_custom_calc => $self->can('custom_idle_calc'),
closure_custom_output => $self->can('custom_idle_output'),
@ -111,9 +121,9 @@ sub set_counters {
closure_custom_perfdata => => $self->can('custom_idle_perfdata')
}
},
{ label => 'listen-queue', nlabel => 'queue.listen.count', set => {
{ label => 'listen-queue', nlabel => 'fpm.queue.listen.count', set => {
key_values => [ { name => 'listen_queue' }, { name => 'max_listen_queue' } ],
output_template => 'Listen queue : %s',
output_template => 'listen queue: %s',
output_use => 'listen_queue', threshold_use => 'listen_queue',
perfdatas => [
{ label => 'listen_queue', template => '%s',
@ -121,9 +131,9 @@ sub set_counters {
]
}
},
{ label => 'requests', nlabel => 'requests.count', set => {
{ label => 'requests', nlabel => 'fpm.requests.persecond', set => {
key_values => [ { name => 'request', per_second => 1 } ],
output_template => 'Requests : %.2f/s',
output_template => 'requests: %.2f/s',
perfdatas => [
{ label => 'requests', template => '%.2f', unit => '/s', min => 0 }
]
@ -146,7 +156,7 @@ sub new {
'basic' => { name => 'basic' },
'username:s' => { name => 'username' },
'password:s' => { name => 'password' },
'timeout:s' => { name => 'timeout', default => 5 },
'timeout:s' => { name => 'timeout', default => 5 }
});
$self->{http} = centreon::plugins::http->new(%options);
@ -163,19 +173,18 @@ sub check_options {
sub manage_selection {
my ($self, %options) = @_;
my $webcontent = $self->{http}->request();
$self->{fpm} = { request => undef, listen_queue => undef, max_listen_queue => undef,
idle => undef, active => undef, total => undef };
$self->{fpm} = {};
$self->{fpm}->{request} = $1 if ($webcontent =~ /accepted\s+conn:\s+(\d+)/msi);
$self->{fpm}->{listen_queue} = $1 if ($webcontent =~ /listen\s+queue:\s+(\d+)/msi);
$self->{fpm}->{max_listen_queue} = $1 if ($webcontent =~ /max\s+listen\s+queue:\s+(\d+)/msi);
$self->{fpm}->{idle} = $1 if ($webcontent =~ /idle\s+processes:\s+(\d+)/msi);
$self->{fpm}->{active} = $1 if ($webcontent =~ /active\s+processes:\s+(\d+)/msi);
$self->{fpm}->{total} = $1 if ($webcontent =~ /total\s+processes:\s+(\d+)/msi);
$self->{cache_name} = "php_fpm_" . $self->{mode} . '_' . $self->{option_results}->{hostname} . '_' . $self->{http}->get_port() . '_' .
$self->{cache_name} = 'php_fpm_' . $self->{mode} . '_' . $self->{option_results}->{hostname} . '_' . $self->{http}->get_port() . '_' .
(defined($self->{option_results}->{filter_counters}) ? md5_hex($self->{option_results}->{filter_counters}) : md5_hex('all'));
}
@ -229,18 +238,12 @@ Specify this option if you access server-status page over hidden basic authentic
Threshold for HTTP timeout (Default: 5)
=item B<--warning-*>
=item B<--warning-*> B<--critical-*>
Threshold warning.
Thresholds.
Can be: 'active-processes' (%), 'idle-processes' (%),
'listen-queue', 'requests'.
=item B<--critical-*>
Threshold critical.
Can be: 'active-processes' (%), 'idle-processes' (%),
'listen-queue', 'requests'.
=back
=cut